From d8d105c9ae38e29b48172d345f49c8a751bca72a Mon Sep 17 00:00:00 2001 From: Alan Mason <1923621+2Shirt@users.noreply.github.com> Date: Thu, 23 Nov 2017 15:24:53 -0800 Subject: [PATCH] Set core.autocrlf to false * This should (hopefully) allow for tagged releases to have the correct line endings. --- .bin/ConEmu/ConEmu.xml | 1574 +++++++-------- .bin/HWiNFO/general.ini | 1328 ++++++------ .bin/Scripts/Copy WizardKit.cmd | 304 +-- .bin/Scripts/Launch.cmd | 990 ++++----- .bin/Scripts/Launcher_Template.cmd | 224 +-- .bin/Scripts/activate.py | 120 +- .bin/Scripts/borrowed/acpi.py | 114 +- .bin/Scripts/borrowed/knownpaths-LICENSE.txt | 42 +- .bin/Scripts/borrowed/knownpaths.py | 328 +-- .bin/Scripts/build_kit.ps1 | 340 ++-- .bin/Scripts/cbs_fix.py | 84 +- .bin/Scripts/check_disk.py | 112 +- .bin/Scripts/compress_bin.cmd | 54 +- .bin/Scripts/dism.py | 114 +- .bin/Scripts/functions/activation.py | 132 +- .bin/Scripts/functions/browsers.py | 894 ++++----- .bin/Scripts/functions/cleanup.py | 182 +- .bin/Scripts/functions/common.py | 1370 ++++++------- .bin/Scripts/functions/data.py | 1216 +++++------ .bin/Scripts/functions/diags.py | 228 +-- .bin/Scripts/functions/info.py | 930 ++++----- .bin/Scripts/functions/partition_uids.py | 650 +++--- .bin/Scripts/functions/product_keys.py | 222 +- .bin/Scripts/functions/repairs.py | 252 +-- .bin/Scripts/functions/setup.py | 544 ++--- .bin/Scripts/functions/update.py | 1786 ++++++++--------- .bin/Scripts/init_client_dir.cmd | 156 +- .bin/Scripts/install_sw_bundle.py | 118 +- .bin/Scripts/install_vcredists.py | 68 +- .bin/Scripts/safemode_enter.py | 88 +- .bin/Scripts/safemode_exit.py | 84 +- .bin/Scripts/settings/launchers.py | 1172 +++++------ .bin/Scripts/settings/main.py | 136 +- .bin/Scripts/settings/music.py | 140 +- .bin/Scripts/settings/sources.py | 406 ++-- .bin/Scripts/settings/tools.py | 110 +- .bin/Scripts/sfc_scan.py | 78 +- .bin/Scripts/system_checklist.py | 212 +- .bin/Scripts/system_diagnostics.py | 246 +-- .bin/Scripts/transferred_keys.py | 56 +- .bin/Scripts/update_kit.py | 284 +-- .bin/Scripts/user_checklist.py | 166 +- .bin/Scripts/user_data_transfer.py | 106 +- .bin/_Drivers/SDIO/sdi.cfg | 46 +- .cbin/_include/AIDA64/full.rpf | 198 +- .cbin/_include/AIDA64/installed_programs.rpf | 2 +- .cbin/_include/AIDA64/licenses.rpf | 2 +- .../BleachBit.ini | 154 +- .cbin/_include/NotepadPlusPlus/config.xml | 112 +- .cbin/_include/XMPlay/xmplay.ini | 278 +-- .cbin/_include/XYplorerFree/Data/XYplorer.ini | Bin 80190 -> 40099 bytes .cbin/_include/_Office/365_32.xml | 12 +- .cbin/_include/_Office/365_64.xml | 12 +- .cbin/_include/_Office/hb_32.xml | 12 +- .cbin/_include/_Office/hb_64.xml | 12 +- .cbin/_include/_Office/hs_32.xml | 12 +- .cbin/_include/_Office/hs_64.xml | 12 +- .cbin/_include/_vcredists/InstallAll.bat | 42 +- .root_items/Drivers/Extras/AMD.url | 4 +- .../Dell (FTP - Browse for Drivers).url | 4 +- .../Extras/Dell (Simplified Interface).url | 4 +- .../Drivers/Extras/Dell (Support Site).url | 12 +- .root_items/Drivers/Extras/Device Remover.url | 10 +- .../Extras/Display Driver Uninstaller.url | 10 +- .root_items/Drivers/Extras/HP.url | 4 +- .../Intel Driver & Support Assistant.url | 10 +- .root_items/Drivers/Extras/NVIDIA.url | 4 +- .../Extras/Samsung Tools & Software.url | 10 +- .root_items/Installers/BackBlaze.url | 10 +- .../Misc/Fix Missing Optical Drive.reg | 10 +- .../Misc/Nirsoft Utilities - Outlook.url | 12 +- .../Misc/Nirsoft Utilities - Passwords.url | 12 +- .../Misc/Sysinternals Suite (Live).url | 10 +- .../AV Removal Tools/AV Removal Tools.url | 10 +- .../Uninstallers/AV Removal Tools/AVG.url | 10 +- .../Uninstallers/AV Removal Tools/Avast.url | 12 +- .../Uninstallers/AV Removal Tools/Avira.url | 12 +- .../Uninstallers/AV Removal Tools/ESET.url | 12 +- .../AV Removal Tools/Kaspersky.url | 12 +- .../Uninstallers/AV Removal Tools/MBAM.url | 10 +- .../Uninstallers/AV Removal Tools/McAfee.url | 10 +- .../Uninstallers/AV Removal Tools/Norton.url | 10 +- Build Kit.cmd | 126 +- LICENSE.txt | 12 +- README.md | 60 +- 85 files changed, 9544 insertions(+), 9544 deletions(-) rename .cbin/_include/{BleachBit-Portable => BleachBit}/BleachBit.ini (95%) diff --git a/.bin/ConEmu/ConEmu.xml b/.bin/ConEmu/ConEmu.xml index c60c311b..dd6ee9b1 100644 --- a/.bin/ConEmu/ConEmu.xml +++ b/.bin/ConEmu/ConEmu.xml @@ -1,787 +1,787 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/.bin/HWiNFO/general.ini b/.bin/HWiNFO/general.ini index a77fb596..1745ddb0 100644 --- a/.bin/HWiNFO/general.ini +++ b/.bin/HWiNFO/general.ini @@ -1,664 +1,664 @@ -[Benchmark_CPU] -Intel Pentium-100=707 -Intel Pentium-120/Notebook=835 -Intel Pentium-166/QDI=1380 -Cyrix 6x86MX-PR300=1411 -AMD-K6-166/QDI=1482 -Intel Pentium MMX-200=1484 -Cyrix MII-PR333=1518 -Intel Mobile Pentium MMX-233=1642 -Intel Pentium Pro-166 Dual CPU=1679 -AMD-K6-200/DTK=1777 -AMD-K6-200/QDI=1778 -Intel Pentium Pro-200=1944 -AMD-K6-233/DTK=2067 -Intel P2-233/Siemens=2350 -VIA Cyrix III 533/133=2362 -Intel Celeron-266/BXmaster=2586 -Intel P2-266/Siemens=2603 -AMD-K6-2-300/PCChips M577=2655 -Intel Celeron 300=2883 -Intel Celeron-300/PCChips=2922 -AMD-K6-2-350/FIC=3092 -AMD-K6-III-400=3524 -AMD-K6-III-400/FIC VA-503A=3557 -Intel Celeron-366/BXmaster=3718 -Intel P2-400/Siemens=3886 -Intel Celeron-400/BXmaster=3890 -AMD-K6-2-450/FIC=3964 -AMD-K6-III-448/FIC VA-503A=3975 -AMD-K6-III-450=3978 -Intel Mobile P2-400/Scenic=4047 -Intel Celeron-413/BXmaster=4175 -Intel Celeron-433=4219 -Intel P3-450/CC820=4363 -Intel P3-450/Siemens=4372 -Intel Celeron-450=4555 -Intel Celeron-300A@467=4686 -Intel Celeron-466/BXmaster=4789 -Intel P3-500/GA-6BXDS=5021 -Intel Pentium III Xeon-550=5299 -Intel Celeron-525/BXmaster=5314 -Intel P3-550/Siemens=5543 -Intel Celeron-550/BXmaster=5579 -Intel Celeron-575/BXmaster=5845 -Intel Celeron-616/BXmaster=5999 -Intel P3-617/GA-BX2000=6241 -AMD Athlon-600/AMD-750=6303 -AMD Duron-600/KT133=6436 -Intel P3-650/BX=6497 -AMD Athlon-650/KX133=6749 -AMD Duron-650/KT133=6971 -Intel P3-700/BX=7013 -AMD Athlon-700/KX133=7185 -AMD Duron-700/KT133=7507 -Intel Celeron-815/BXmaster=7985 -AMD Athlon-750/KT133=8085 -AMD Athlon-800/AMD-750=8286 -AMD Duron-800/KT133=8580 -Intel P3-650@870/BX=8675 -AMD Duron-850/KT133=9120 -Intel P3-650@917/BX=9175 -AMD Duron-900/KT133=9654 -AMD Duron-928 (9x103)=9952 -Intel Celeron-566@1010=10115 -VIA Antaur-1000=6108 -VIA C3-1333=7601 -AMD Duron-950/KT133=10190 -AMD Athlon-1000/KT133=10734 -AMD Athlon-1200/KT133=12949 -AMD Athlon XP 1500+/KT133=14297 -AMD Athlon XP 2000+/KT133A=17691 -AMD Athlon XP 2200+/KT133A=19490 -AMD Athlon XP-M 2500+/KM400=19590 -AMD Athlon XP-M 3000+/SiS748=23391 -Intel P3-1000/i815=10381 -Intel P4-1600=6636 -Intel P4-1800=7445 -Intel P4-2000=8272 -Intel P4-2500=11051 -Intel Pentium-M ULV-1000=10515 -Intel Pentium-M-1300=13590 -Intel Pentium-M-1600=16856 -Intel Pentium-M 735=16958 -Intel Pentium-M 755=20008 -Intel Pentium-M 770=21163 -Intel P4-2800(noHT)/i875P=12399 -Intel P4-3066(noHT)/i845PE=13479 -Intel P4-3000E(noHT)/i915P=22136 -Intel P4-3000 530 (HT)=34013 -Intel P4-3200E(noHT)/i875P=23446 -Intel P4-3600E(noHT)/i925X=26424 -Intel Xeon-3800(HT)=55028 -AMD Athlon64 3200+=23814 -AMD Athlon64 3800+=28731 -AMD Athlon64 FX-53=28727 -AMD Opteron 248=25920 -AMD Turion64 ML-34+=18520 -AMD Turion64 X2 TL-60=47697 -AMD Athlon 64 X2 4400+=52867 -Intel Core Duo T2600 (1core)=20293 -Intel Core Duo T2600 (2core)=40849 -Intel Core 2 Duo E6700=51765 -Intel Core 2 Duo T7400=53238 -Transmeta Crusoe TM5800-1000=6382 -2xIntel Xeon 5150/5000P=131832 -4xIntel Xeon MP 7040=180052 -Intel Core 2 Extreme QX6700=129908 -AMD Phenom 9500=103687 -Intel Atom 230=15438 -Intel Core i5-520M=94834 -Intel Core i7-860=180329 -Intel Core i7-820QM=123279 -Intel Core i7-980X=347501 -Intel Core i5-2520M=111448 -Intel Core i7-3820=265424 - -[Benchmark_FPU] -Intel Pentium-100=1109 -VIA Cyrix III 533/133=1327 -Intel Pentium 120/Notebook=1350 -Intel Pentium Pro-166 Dual CPU=1663 -Intel Pentium Pro-200=1934 -Cyrix 6x86MX-PR300=2304 -Intel P2-233/Siemens=2323 -AMD-K6-166/QDI=2533 -Cyrix MII-PR333=2585 -Intel Celeron-266/BXmaster=2630 -Intel Mobile Pentium MMX-233=2647 -Intel P2-266/Siemens=2662 -Intel Celeron-300=2862 -AMD-K6-200/DTK=2999 -AMD-K6-200/QDI=3041 -AMD-K6-233/DTK=3492 -Intel Celeron-366/BXmaster=3650 -Intel P2-400/Siemens=3968 -Intel Celeron-400/BXmaster=3972 -Intel Mobile P2-400/Scenic=3973 -Intel Celeron-413/BXmaster=4097 -Intel Celeron-433=4304 -Intel P3-450/CC820=4444 -Intel P3-450/Siemens=4452 -Intel Celeron-450=4472 -Intel Celeron-300A@467=4599 -AMD-K6-2-300/PCChips M577=4605 -Intel Celeron-466/BXmaster=4628 -Intel P3-500/GA-6BXDS=4958 -Intel Celeron-525/BXmaster=5215 -AMD-K6-2-350/FIC=5368 -Intel Pentium III Xeon-550=5417 -Intel P3-550/Siemens=5440 -Intel Celeron-550/BXmaster=5477 -Intel Celeron-575/BXmaster=5738 -Intel Celeron-616/BXmaster=5897 -Intel P3-617/GA-BX2000=6114 -AMD-K6-III-400/FIC VA-503A=6166 -AMD-K6-III-400=6169 -Intel P3-650/BX=6446 -AMD-K6-2-450/FIC=6876 -AMD-K6-III-448/FIC VA-503A=6893 -AMD-K6-III-450=6895 -Intel P3-700/BX=6942 -Intel Celeron-815/BXmaster=7799 -Intel P3-650@870/BX=8614 -Intel P3-650@917/BX=9080 -VIA C3-1333=3160 -AMD Duron-600/KT133=9132 -AMD Athlon-600/AMD-750=9231 -AMD Athlon-650/KX133=9888 -Intel Celeron-566@1010=9977 -AMD Athlon-700/KX133=10527 -AMD Athlon-750/KT133=11457 -AMD Athlon-800/AMD-750=12149 -AMD Duron-850/KT133=12954 -AMD Duron-900/KT133=13712 -AMD Duron-928 (9x103)=14150 -AMD Duron-950/KT133=14479 -AMD Athlon-1000/KT133=15252 -AMD Athlon-1200/KT133=18378 -AMD Athlon XP 1500+/KT133=20757 -AMD Athlon XP 1800+=23375 -AMD Athlon XP 2000+/KT133A=25693 -AMD Athlon XP 2200+/KT133A=28296 -AMD Athlon XP-M 2500+/KM400=28877 -AMD Athlon XP-M 3000+/SiS748=34104 -Intel P3-1000/i815=9813 -Intel P4-1600=3282 -Intel P4-1800=3833 -Intel P4-2000=4256 -Intel P4-2500=6020 -Intel Pentium-M ULV-1000=8547 -Intel Pentium-M-1300=11089 -Intel Pentium-M-1600=13614 -Intel Pentium-M 735=14211 -Intel Pentium-M 755=16772 -Intel Pentium-M 770=17807 -Intel P4-2800(noHT)/i875P=6799 -Intel P4-3066(noHT)/i845PE=7396 -Intel P4-3000 530 (HT)=9220 -Intel P4-3200E(noHT)/i875P=6578 -Intel P4-3600E(noHT)/i925X=8163 -Intel Xeon-3800(HT)=17241 -AMD Athlon64 3200+=31194 -AMD Athlon64 3800+=37379 -AMD Athlon64 FX-53=37426 -AMD Opteron 248=34115 -AMD Turion64 ML-34+=28056 -AMD Turion64 X2 TL-60=62143 -AMD Athlon 64 X2 4400+=68974 -Intel Core Duo T2600 (1core)=16967 -Intel Core Duo T2600 (2core)=34039 -Intel Core 2 Duo E6600=36031 -Intel Core 2 Duo E6700=40075 -Intel Core 2 Duo T7400=32659 -Transmeta Crusoe TM5800-1000=4251 -2xIntel Xeon 5150/5000P=80725 -4xIntel Xeon MP 7040=54379 -Intel Core 2 Extreme QX6700=80338 -AMD Phenom 9500=133430 -Intel Atom 230=10769 -Intel Core i5-520M=60634 -Intel Core i7-860=131820 -Intel Core i7-820QM=90751 -Intel Core i7-980X=215620 -Intel Core i5-2520M=55354 -Intel Core i7-3820=130252 - -[Benchmark_MMX] -AMD-K6-166/QDI=909 -AMD-K6-200/QDI=1070 -Intel P2-266/440LX=1339 -VIA Cyrix III 533/133=1815 -Intel Pentium MMX-200=2041 -Intel Mobile Pentium MMX-233=2363 -Intel P2-233/440BX=2390 -Intel Celeron-300=2931 -Intel Celeron-366=3742 -Intel Celeron-450=4602 -Intel Celeron-300A@467=4737 -Intel P3-500/GA-6BXDS=5009 -AMD Duron-600/KT133=5454 -Intel P3-550/Siemens=5513 -AMD Athlon-650/KX133=5906 -AMD Athlon-700/Abit KA7=6356 -Intel P3-650/BX=6490 -AMD Duron-750/KT133=6823 -AMD Athlon-750/KT133=6846 -Intel P3-700/BX=7025 -AMD Duron-800/KT133=7277 -AMD Duron-850/KT133=7738 -AMD Duron-900/KT133=8192 -AMD Duron-928 (9x103)=8448 -AMD Duron-950/KT133=8645 -Intel P3-650@870/BX=8706 -AMD Athlon-1000/KT133=9110 -Intel P3-650@917/BX=9173 -Intel Celeron-566@1010=10080 -VIA C3-1333=6063 -AMD Athlon-1200/KT133=10998 -AMD Athlon XP 1500+/KT133=12125 -AMD Athlon XP 1800+=13642 -AMD Athlon XP 2000+/KT133A=15013 -AMD Athlon XP 2200+/KT133A=16516 -AMD Athlon XP-M 2500+/KM400=16858 -AMD Athlon XP-M 3000+/SiS748=20040 -Intel P3-1000=9903 -Intel P4-1600=14468 -Intel P4-1800=16319 -Intel P4-2000=18140 -Intel P4-2500=22681 -Intel Pentium-M ULV-1000=9937 -Intel Pentium-M-1300=12865 -Intel Pentium-M-1600=15835 -Intel Pentium-M 735=16839 -Intel Pentium-M 755=19869 -Intel Pentium-M 770=21149 -Intel P4-2800(noHT)/i875P=24478 -Intel P4-3066(noHT)/i845PE=26437 -Intel P4-3000 530 (HT)=27352 -Intel P4-3200E(noHT)/i875P=22592 -Intel P4-3600E(noHT)/i925X=25314 -Intel Xeon-3800(HT)=53268 -AMD Athlon64 3200+=18228 -AMD Athlon64 3800+=21859 -AMD Athlon64 FX-53=21856 -AMD Opteron 248=19926 -AMD Turion64 ML-34+=16403 -AMD Turion64 X2 TL-60=36363 -AMD Athlon 64 X2 4400+=40282 -Intel Core Duo T2600 (1core)=21423 -Intel Core Duo T2600 (2core)=42912 -Intel Core 2 Duo E6600=74154 -Intel Core 2 Duo E6700=82312 -Intel Core 2 Duo T7400=67321 -Transmeta Crusoe TM5800-1000=5272 -2xIntel Xeon 5150/5000P=51186 -4xIntel Xeon MP 7040=83086 -Intel Core 2 Extreme QX6700=165067 -AMD Phenom 9500=80202 -Intel Atom 230=14545 -Intel Core i5-520M=80822 -Intel Core i7-860=171336 -Intel Core i7-820QM=115063 -Intel Core i7-980X=261051 -Intel Core i5-2520M=81444 -Intel Core i7-3820=160178 - -[Benchmark_Memory] -Intel Pentium-100/FPM=69 -Intel Pentium Pro-166 Dual CPU=78 -AMD-K6-166/QDI/EDO=85 -Intel Pentium MMX-200/EDO=92 -AMD-K6-200/QDI/EDO=93 -Intel Pentium MMX-233/PC66=101 -Intel P2-233/440BX/PC66=111 -VIA Cyrix III 533/133=114 -Intel P2-266/440BX/PC66=117 -AMD-K6-III-400=135 -Intel Celeron-366/PC66=163 -AMD Duron-600/KT133=173 -AMD Athlon-700/KX133/PC133=202 -AMD Athlon-650/KX133=205 -Intel P3-500/GA-6BXDS/PC100=209 -Intel P3-550/Siemens/PC100=215 -Intel Celeron-300A@467/PC66=209 -Intel Celeron-300/PC66=146 -Intel P3-650/BX/PC100=238 -Intel P3-700/BX/PC100=211 -AMD Athlon-750/KT133/PC133=214 -AMD Duron-750/KT133=263 -Intel Celeron-566@1010=273 -VIA C3-1333/CN400=223 -AMD Duron-950/KT133=275 -AMD Duron-928 (9x103)/KT133=292 -AMD Duron-1100/SiS745/DDR333=477 -AMD Athlon XP-M 2500+/DDR333=548 -Intel P3-650@917/FSB140=310 -Intel P3-1000/PC133=218 -Intel P4-1600/i850=1115 -Intel P4-2000/i850/PC800=1245 -Intel P4-1800/i845G/DDR266=867 -Intel P4-2500/i845/DDR266=757 -Intel Pentium-M-1600/DDR266=830 -Intel Pentium-M 735/855PM/DDR400=971 -Intel P4-3066/i845PE/DDR266=1028 -Intel P4-2800/i875P/2Ch/DDR400=2056 -Intel P4-3200E/i875P/2Ch/DDR400=2342 -Intel P4-3600E/i915P/DDR2-533=2556 -Intel P4-3600E/i925X/DDR2-533=2844 -Intel Xeon-3800/E7525/DDR2-400=1635 -AMD Athlon64 3200+/1Ch/DDR400=1266 -AMD Athlon64 3800+/2Ch/DDR400=2375 -AMD Athlon64 FX-53/2Ch/DDR400=2166 -AMD Opteron 248/DDR266=947 -AMD Turion64 ML-34+=1071 -Intel Core 2 Duo E6700/DDR2-800=2894 -Transmeta Crusoe TM5800-1000=337 -2xIntel Xeon 5150/5000P/DDR2-667F=2919 -4xIntel Xeon MP 7040=1721 -AMD Phenom 9500=1795 -Intel Atom 230/945/DDR2-800=1682 -Intel Core i5-520M=5235 -Intel Core i7-860/DDR3-667/2CH=6506 -Intel Core i7-820QM=5424 -Intel Core i7-980X=9343 -Intel Core i7-3820/DDR3-1600/4CH=13366 - -[Benchmark_Disk_ReadBurst] -Fujitsu MPB3043ATU E/PIO=4.03 -Seagate ST38410A/PIO=4.33 -Maxtor 91021U2/PIO=4.61 -Maxtor 92041U4/PIO=4.82 -Quantum Fireball_TM2110S300X=6.83 -SEAGATE ST51080N=7.92 -Seagate ST31277A=8,37 -IBM DCAS-32160 S65A=8.65 -QUANTUM FIREBALL ST3.2A/PIO=14.74 -Seagate ST39102LW Cheetah=30.05 -IBM DJNA-370910/UDMA66=15.27 -Seagate ST34321A/UDMA33=21.03 -Seagate ST38421A=23.82 -Seagate ST34310A=23.88 -QUANTUM FIREBALL SE2.1A=26.43 -Maxtor 91021U2/UDMA33=29.13 -Maxtor 54098U8/UDMA33=29.5 -IBM DTTA-350430=29.7 -IBM-DPTA-371360=29.86 -Seagate ST320420A=47.3 -IBM-DJNA-371350=27.87 -IBM-DTLA-307030/ATA100=82.22 -SEAGATE Cheetah X15/RAID=137.08 -IBM Deskstar 60GXP/ATA100=81.98 -MAXTOR 4K020H1/ATA100=84.58 -Seagate ST317221A/UDMA66=42.03 -Maxtor 6E040L0=79.36 -Seagate ST380021A/ATA100=73.11 -HITACHI DK23EA-40=80.04 -WDC WD800JB/ATA100=85.71 -TOSHIBA MK4019GAX=83.60 -Maxtor MaxLine III SATA+NCQ=119.96 -ST312002 6AS=106.61 -Maxtor Atlas 10K5 73SCA=145.86 -WDC WD3200YS-01PGB0=167.33 -Hitachi HTE726040M9AT00=84.61 -Seagate ST3160827AS=120.88 -WDC WD5000AADS-00S9B0=122.87 -Hitachi HTS545032B9A=161.10 -Seagate ST1000DM003-9YN1=282.43 - -[Benchmark_Disk_ReadRandom] -Hitachi HTE726040M9AT00=22.82 -Maxtor Atlas 10K5 73SCA=31.61 -Seagate ST3160827AS=32.26 -FUJITSU MHV2080BH=17.79 -TOSHIBA MK8034GSX=18.12 -ST916082 1AS=22.27 -WDC WD5000AADS-00S9B0=24.58 -Hitachi HTS545032B9A=24.72 -Seagate ST1000DM003-9YN1=37.09 - -[Benchmark_Disk_RandomAccess] -SEAGATE ST51080N=20.96 -Quantum Fireball_TM2110S300X=20.74 -Seagate ST34321A/UDMA33=17.21 -Seagate ST38410A/PIO=17.17 -Seagate ST31277A=16.75 -Fujitsu MPB3043ATU E=16.18 -IBM DTTA-350430=16.5 -IBM DCAS-32160 S65A=15.95 -Maxtor 92041U4/PIO=15.81 -Seagate ST34310A=15.56 -Maxtor 91021U2/PIO=15.66 -Seagate ST38421A=15.71 -QUANTUM FIREBALL ST3.2A=15.50 -QUANTUM FIREBALL SE2.1A=14.94 -Maxtor 54098U8/UDMA33=13.77 -Seagate ST320420A=12.57 -IBM DJNA-370910/UDMA66=12.10 -Seagate ST39102LW Cheetah=8.78 -IBM-DPTA-371360=13.37 -IBM-DJNA-371350=13.38 -IBM-DTLA-307030/ATA100=12.44 -IBM-DTLA-307030/ATA100+AAM=22.34 -SEAGATE Cheetah X15/RAID=5.65 -IBM Deskstar 60GXP=12.70 -MAXTOR 4K020H1/ATA100=19.12 -Seagate ST317221A/UDMA66=16.60 -Maxtor 6E040L0=14.52 -Seagate ST380021A/ATA100=14.58 -HITACHI DK23EA-40=19.40 -WDC WD800JB/ATA100=13.61 -TOSHIBA MK4019GAX=18.61 -Maxtor MaxLine III SATA+NCQ=15.82 -ST312002 6AS=12.51 -Maxtor Atlas 10K5 73SCA=10.16 -WDC WD3200YS-01PGB0=13.16 -Hitachi HTE726040M9AT00=12.90 -Seagate ST3160827AS=11.65 -Seagate ST380215A=14.82 -WDC WD5000AADS-00S9B0=17.37 -Hitachi HTS545032B9A=22.16 -Seagate ST1000DM003-9YN1=15.53 - -[LogfileSettings] -COMP=1 -COMP_SP=1 -COMP_Name=1 -COMP_Os=1 -COMP_User=0 -CPU=1 -CPU_Name=1 -CPU_ID=1 -CPU_Vendor=1 -CPU_Stepping=1 -CPU_Type=1 -CPU_BrandID=1 -CPU_PN=1 -CPU_Clock=1 -CPU_MaxFreq=1 -CPU_CacheL1=1 -CPU_CacheL2=1 -CPU_TLB_I=1 -CPU_TLB_D=1 -CPU_Features=1 -CPU_PIROM=1 -MEM=1 -MEM_TotalSize=1 -MEM_Timing=1 -MEM_Row=1 -MEM_Row_Size=1 -MEM_Row_Type=1 -MEM_Row_Speed=1 -MEM_Row_Model=1 -MEM_Row_ECC=1 -MEM_Row_Date=1 -MEM_Row_SN=1 -MEM_Row_Cfg=1 -MEM_Row_Latency=1 -MEM_Row_Features=1 -MEM_Row_iFeatures=1 -BUS=1 -BUS_PCI=1 -BUS_PCI_DevName=1 -BUS_PCI_DevNumber=1 -BUS_PCI_Resources=1 -BUS_PCI_Features=1 -BUS_PCI_DevSpecific=1 -BUS_PCIX_Features=1 -BUS_PCIe_Features=1 -BUS_PCI_DRV_INFO=1 -BUS_EISA=1 -DMI=1 -DMI_0=1 -DMI_1=1 -DMI_2=1 -DMI_3=1 -DMI_4=1 -DMI_5=1 -DMI_6=1 -DMI_7=1 -DMI_8=1 -DMI_9=1 -DMI_10=1 -DMI_11=1 -DMI_12=1 -DMI_13=1 -DMI_14=1 -DMI_15=1 -DMI_16=1 -DMI_17=1 -DMI_18=1 -DMI_19=1 -DMI_20=1 -DMI_21=1 -DMI_22=1 -DMI_23=1 -DMI_24=1 -DMI_25=1 -DMI_26=1 -DMI_27=1 -DMI_28=1 -DMI_29=1 -DMI_30=1 -DMI_31=1 -DMI_32=1 -DMI_33=1 -DMI_34=1 -DMI_35=1 -DMI_36=1 -DMI_37=1 -DMI_38=1 -DMI_39=1 -DMI_129=1 -DMI_130=1 -DMI_131=1 -VIDEO=1 -VIDEO_Chipset=1 -VIDEO_Memory=1 -VIDEO_Card=1 -VIDEO_Bus=1 -VIDEO_RAMDAC=1 -VIDEO_BIOSver=1 -VIDEO_Clock=1 -VIDEO_HWID=1 -VIDEO_DRV_INFO=1 -VIDEO_DirectX=1 -MON=1 -MON_Name=1 -MON_SN=1 -MON_Date=1 -MON_Dimensions=1 -MON_DisplayType=1 -MON_InputSignal=1 -MON_Gamma=1 -MON_DPMSinput=1 -MON_DPMSmodes=1 -MOBO=1 -MOBO_Model=1 -MOBO_Chipset=1 -MOBO_CompName=1 -MOBO_MachineType=1 -MOBO_Slots=1 -MOBO_BIOS_Manuf=1 -MOBO_BIOS_Date=1 -MOBO_PNP_Devs=1 -MOBO_PNP_Nodes=1 -MOBO_ACPI_Devs=1 -MOBO_ACPI_Enum=1 -DRIVE=1 -DRIVE_IDE=1 -DRIVE_IDE_Ctrller=1 -DRIVE_IDE_Channel=1 -DRIVE_IDE_Model=1 -DRIVE_IDE_Rev=1 -DRIVE_IDE_SN=1 -DRIVE_IDE_Capacity=1 -DRIVE_IDE_Geometry=1 -DRIVE_IDE_Cache=1 -DRIVE_IDE_Xfer=1 -DRIVE_IDE_BasicCapab=1 -DRIVE_IDE_ATA2Capab=1 -DRIVE_IDE_SMART=1 -DRIVE_SCSI=1 -DRIVE_SCSI_ID=1 -DRIVE_SCSI_Desc=1 -DRIVE_SCSI_Class=1 -DRIVE_Floppy=1 -NETWORK=1 -NETWORK_HWID=1 -NETWORK_DRV_INFO=1 -AUDIO=1 -AUDIO_DRV_INFO=1 -AUDIO_HWID=1 -PORTS=1 -BUS_USB=1 -BUS_USB_DRV_INFO=1 -BATTERY=1 -SENSORS=1 - -[Settings] -AC97CodecID=1 -AcpiEnum=0 -AcpiEval=1 -AutoUpdate=0 -AutoUpdateBetaDisable=1 -BusClkPolling=1 -CpuClkFromBusClk=1 -DebugMode=0 -DefReportType=5 -EC=1 -FlushBuffers=1 -GPUI2C=1 -GPUI2CADL=0 -GPUI2CBusExclude=00000000 -GPUI2CNVAPI=1 -GPUI2Ccaching=1 -HighestIdeAddress=0 -IoctlKernel=0 -KeepTheme=0 -LargeFonts=0 -MinimalizeMainWnd=0 -MinimalizeSensors=0 -OpenSensors=0 -OpenSystemSummary=0 -PCIdirect=1 -PersistentDriver=0 -RememberPreferences=1 -SMBus=1 -SMBusAdrExclude=11111111111111110000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010000000000000000000000 -SWSMI=1 -SensorsSM=1 -ShowWelcomeAndProgress=0 -SkipProblematicPciDev=0 -TPM=0 -TempScale=C -UseHPET=1 -WakeGPUs=1 -iMEsupport=1 -MinimizeGraphs=1 -SensorRowShading=1 -SensorsTopmost=0 -DecimalSeparator=. -ThousandsSeparator=, -CsvSeparator=, -TextButtons=0 +[Benchmark_CPU] +Intel Pentium-100=707 +Intel Pentium-120/Notebook=835 +Intel Pentium-166/QDI=1380 +Cyrix 6x86MX-PR300=1411 +AMD-K6-166/QDI=1482 +Intel Pentium MMX-200=1484 +Cyrix MII-PR333=1518 +Intel Mobile Pentium MMX-233=1642 +Intel Pentium Pro-166 Dual CPU=1679 +AMD-K6-200/DTK=1777 +AMD-K6-200/QDI=1778 +Intel Pentium Pro-200=1944 +AMD-K6-233/DTK=2067 +Intel P2-233/Siemens=2350 +VIA Cyrix III 533/133=2362 +Intel Celeron-266/BXmaster=2586 +Intel P2-266/Siemens=2603 +AMD-K6-2-300/PCChips M577=2655 +Intel Celeron 300=2883 +Intel Celeron-300/PCChips=2922 +AMD-K6-2-350/FIC=3092 +AMD-K6-III-400=3524 +AMD-K6-III-400/FIC VA-503A=3557 +Intel Celeron-366/BXmaster=3718 +Intel P2-400/Siemens=3886 +Intel Celeron-400/BXmaster=3890 +AMD-K6-2-450/FIC=3964 +AMD-K6-III-448/FIC VA-503A=3975 +AMD-K6-III-450=3978 +Intel Mobile P2-400/Scenic=4047 +Intel Celeron-413/BXmaster=4175 +Intel Celeron-433=4219 +Intel P3-450/CC820=4363 +Intel P3-450/Siemens=4372 +Intel Celeron-450=4555 +Intel Celeron-300A@467=4686 +Intel Celeron-466/BXmaster=4789 +Intel P3-500/GA-6BXDS=5021 +Intel Pentium III Xeon-550=5299 +Intel Celeron-525/BXmaster=5314 +Intel P3-550/Siemens=5543 +Intel Celeron-550/BXmaster=5579 +Intel Celeron-575/BXmaster=5845 +Intel Celeron-616/BXmaster=5999 +Intel P3-617/GA-BX2000=6241 +AMD Athlon-600/AMD-750=6303 +AMD Duron-600/KT133=6436 +Intel P3-650/BX=6497 +AMD Athlon-650/KX133=6749 +AMD Duron-650/KT133=6971 +Intel P3-700/BX=7013 +AMD Athlon-700/KX133=7185 +AMD Duron-700/KT133=7507 +Intel Celeron-815/BXmaster=7985 +AMD Athlon-750/KT133=8085 +AMD Athlon-800/AMD-750=8286 +AMD Duron-800/KT133=8580 +Intel P3-650@870/BX=8675 +AMD Duron-850/KT133=9120 +Intel P3-650@917/BX=9175 +AMD Duron-900/KT133=9654 +AMD Duron-928 (9x103)=9952 +Intel Celeron-566@1010=10115 +VIA Antaur-1000=6108 +VIA C3-1333=7601 +AMD Duron-950/KT133=10190 +AMD Athlon-1000/KT133=10734 +AMD Athlon-1200/KT133=12949 +AMD Athlon XP 1500+/KT133=14297 +AMD Athlon XP 2000+/KT133A=17691 +AMD Athlon XP 2200+/KT133A=19490 +AMD Athlon XP-M 2500+/KM400=19590 +AMD Athlon XP-M 3000+/SiS748=23391 +Intel P3-1000/i815=10381 +Intel P4-1600=6636 +Intel P4-1800=7445 +Intel P4-2000=8272 +Intel P4-2500=11051 +Intel Pentium-M ULV-1000=10515 +Intel Pentium-M-1300=13590 +Intel Pentium-M-1600=16856 +Intel Pentium-M 735=16958 +Intel Pentium-M 755=20008 +Intel Pentium-M 770=21163 +Intel P4-2800(noHT)/i875P=12399 +Intel P4-3066(noHT)/i845PE=13479 +Intel P4-3000E(noHT)/i915P=22136 +Intel P4-3000 530 (HT)=34013 +Intel P4-3200E(noHT)/i875P=23446 +Intel P4-3600E(noHT)/i925X=26424 +Intel Xeon-3800(HT)=55028 +AMD Athlon64 3200+=23814 +AMD Athlon64 3800+=28731 +AMD Athlon64 FX-53=28727 +AMD Opteron 248=25920 +AMD Turion64 ML-34+=18520 +AMD Turion64 X2 TL-60=47697 +AMD Athlon 64 X2 4400+=52867 +Intel Core Duo T2600 (1core)=20293 +Intel Core Duo T2600 (2core)=40849 +Intel Core 2 Duo E6700=51765 +Intel Core 2 Duo T7400=53238 +Transmeta Crusoe TM5800-1000=6382 +2xIntel Xeon 5150/5000P=131832 +4xIntel Xeon MP 7040=180052 +Intel Core 2 Extreme QX6700=129908 +AMD Phenom 9500=103687 +Intel Atom 230=15438 +Intel Core i5-520M=94834 +Intel Core i7-860=180329 +Intel Core i7-820QM=123279 +Intel Core i7-980X=347501 +Intel Core i5-2520M=111448 +Intel Core i7-3820=265424 + +[Benchmark_FPU] +Intel Pentium-100=1109 +VIA Cyrix III 533/133=1327 +Intel Pentium 120/Notebook=1350 +Intel Pentium Pro-166 Dual CPU=1663 +Intel Pentium Pro-200=1934 +Cyrix 6x86MX-PR300=2304 +Intel P2-233/Siemens=2323 +AMD-K6-166/QDI=2533 +Cyrix MII-PR333=2585 +Intel Celeron-266/BXmaster=2630 +Intel Mobile Pentium MMX-233=2647 +Intel P2-266/Siemens=2662 +Intel Celeron-300=2862 +AMD-K6-200/DTK=2999 +AMD-K6-200/QDI=3041 +AMD-K6-233/DTK=3492 +Intel Celeron-366/BXmaster=3650 +Intel P2-400/Siemens=3968 +Intel Celeron-400/BXmaster=3972 +Intel Mobile P2-400/Scenic=3973 +Intel Celeron-413/BXmaster=4097 +Intel Celeron-433=4304 +Intel P3-450/CC820=4444 +Intel P3-450/Siemens=4452 +Intel Celeron-450=4472 +Intel Celeron-300A@467=4599 +AMD-K6-2-300/PCChips M577=4605 +Intel Celeron-466/BXmaster=4628 +Intel P3-500/GA-6BXDS=4958 +Intel Celeron-525/BXmaster=5215 +AMD-K6-2-350/FIC=5368 +Intel Pentium III Xeon-550=5417 +Intel P3-550/Siemens=5440 +Intel Celeron-550/BXmaster=5477 +Intel Celeron-575/BXmaster=5738 +Intel Celeron-616/BXmaster=5897 +Intel P3-617/GA-BX2000=6114 +AMD-K6-III-400/FIC VA-503A=6166 +AMD-K6-III-400=6169 +Intel P3-650/BX=6446 +AMD-K6-2-450/FIC=6876 +AMD-K6-III-448/FIC VA-503A=6893 +AMD-K6-III-450=6895 +Intel P3-700/BX=6942 +Intel Celeron-815/BXmaster=7799 +Intel P3-650@870/BX=8614 +Intel P3-650@917/BX=9080 +VIA C3-1333=3160 +AMD Duron-600/KT133=9132 +AMD Athlon-600/AMD-750=9231 +AMD Athlon-650/KX133=9888 +Intel Celeron-566@1010=9977 +AMD Athlon-700/KX133=10527 +AMD Athlon-750/KT133=11457 +AMD Athlon-800/AMD-750=12149 +AMD Duron-850/KT133=12954 +AMD Duron-900/KT133=13712 +AMD Duron-928 (9x103)=14150 +AMD Duron-950/KT133=14479 +AMD Athlon-1000/KT133=15252 +AMD Athlon-1200/KT133=18378 +AMD Athlon XP 1500+/KT133=20757 +AMD Athlon XP 1800+=23375 +AMD Athlon XP 2000+/KT133A=25693 +AMD Athlon XP 2200+/KT133A=28296 +AMD Athlon XP-M 2500+/KM400=28877 +AMD Athlon XP-M 3000+/SiS748=34104 +Intel P3-1000/i815=9813 +Intel P4-1600=3282 +Intel P4-1800=3833 +Intel P4-2000=4256 +Intel P4-2500=6020 +Intel Pentium-M ULV-1000=8547 +Intel Pentium-M-1300=11089 +Intel Pentium-M-1600=13614 +Intel Pentium-M 735=14211 +Intel Pentium-M 755=16772 +Intel Pentium-M 770=17807 +Intel P4-2800(noHT)/i875P=6799 +Intel P4-3066(noHT)/i845PE=7396 +Intel P4-3000 530 (HT)=9220 +Intel P4-3200E(noHT)/i875P=6578 +Intel P4-3600E(noHT)/i925X=8163 +Intel Xeon-3800(HT)=17241 +AMD Athlon64 3200+=31194 +AMD Athlon64 3800+=37379 +AMD Athlon64 FX-53=37426 +AMD Opteron 248=34115 +AMD Turion64 ML-34+=28056 +AMD Turion64 X2 TL-60=62143 +AMD Athlon 64 X2 4400+=68974 +Intel Core Duo T2600 (1core)=16967 +Intel Core Duo T2600 (2core)=34039 +Intel Core 2 Duo E6600=36031 +Intel Core 2 Duo E6700=40075 +Intel Core 2 Duo T7400=32659 +Transmeta Crusoe TM5800-1000=4251 +2xIntel Xeon 5150/5000P=80725 +4xIntel Xeon MP 7040=54379 +Intel Core 2 Extreme QX6700=80338 +AMD Phenom 9500=133430 +Intel Atom 230=10769 +Intel Core i5-520M=60634 +Intel Core i7-860=131820 +Intel Core i7-820QM=90751 +Intel Core i7-980X=215620 +Intel Core i5-2520M=55354 +Intel Core i7-3820=130252 + +[Benchmark_MMX] +AMD-K6-166/QDI=909 +AMD-K6-200/QDI=1070 +Intel P2-266/440LX=1339 +VIA Cyrix III 533/133=1815 +Intel Pentium MMX-200=2041 +Intel Mobile Pentium MMX-233=2363 +Intel P2-233/440BX=2390 +Intel Celeron-300=2931 +Intel Celeron-366=3742 +Intel Celeron-450=4602 +Intel Celeron-300A@467=4737 +Intel P3-500/GA-6BXDS=5009 +AMD Duron-600/KT133=5454 +Intel P3-550/Siemens=5513 +AMD Athlon-650/KX133=5906 +AMD Athlon-700/Abit KA7=6356 +Intel P3-650/BX=6490 +AMD Duron-750/KT133=6823 +AMD Athlon-750/KT133=6846 +Intel P3-700/BX=7025 +AMD Duron-800/KT133=7277 +AMD Duron-850/KT133=7738 +AMD Duron-900/KT133=8192 +AMD Duron-928 (9x103)=8448 +AMD Duron-950/KT133=8645 +Intel P3-650@870/BX=8706 +AMD Athlon-1000/KT133=9110 +Intel P3-650@917/BX=9173 +Intel Celeron-566@1010=10080 +VIA C3-1333=6063 +AMD Athlon-1200/KT133=10998 +AMD Athlon XP 1500+/KT133=12125 +AMD Athlon XP 1800+=13642 +AMD Athlon XP 2000+/KT133A=15013 +AMD Athlon XP 2200+/KT133A=16516 +AMD Athlon XP-M 2500+/KM400=16858 +AMD Athlon XP-M 3000+/SiS748=20040 +Intel P3-1000=9903 +Intel P4-1600=14468 +Intel P4-1800=16319 +Intel P4-2000=18140 +Intel P4-2500=22681 +Intel Pentium-M ULV-1000=9937 +Intel Pentium-M-1300=12865 +Intel Pentium-M-1600=15835 +Intel Pentium-M 735=16839 +Intel Pentium-M 755=19869 +Intel Pentium-M 770=21149 +Intel P4-2800(noHT)/i875P=24478 +Intel P4-3066(noHT)/i845PE=26437 +Intel P4-3000 530 (HT)=27352 +Intel P4-3200E(noHT)/i875P=22592 +Intel P4-3600E(noHT)/i925X=25314 +Intel Xeon-3800(HT)=53268 +AMD Athlon64 3200+=18228 +AMD Athlon64 3800+=21859 +AMD Athlon64 FX-53=21856 +AMD Opteron 248=19926 +AMD Turion64 ML-34+=16403 +AMD Turion64 X2 TL-60=36363 +AMD Athlon 64 X2 4400+=40282 +Intel Core Duo T2600 (1core)=21423 +Intel Core Duo T2600 (2core)=42912 +Intel Core 2 Duo E6600=74154 +Intel Core 2 Duo E6700=82312 +Intel Core 2 Duo T7400=67321 +Transmeta Crusoe TM5800-1000=5272 +2xIntel Xeon 5150/5000P=51186 +4xIntel Xeon MP 7040=83086 +Intel Core 2 Extreme QX6700=165067 +AMD Phenom 9500=80202 +Intel Atom 230=14545 +Intel Core i5-520M=80822 +Intel Core i7-860=171336 +Intel Core i7-820QM=115063 +Intel Core i7-980X=261051 +Intel Core i5-2520M=81444 +Intel Core i7-3820=160178 + +[Benchmark_Memory] +Intel Pentium-100/FPM=69 +Intel Pentium Pro-166 Dual CPU=78 +AMD-K6-166/QDI/EDO=85 +Intel Pentium MMX-200/EDO=92 +AMD-K6-200/QDI/EDO=93 +Intel Pentium MMX-233/PC66=101 +Intel P2-233/440BX/PC66=111 +VIA Cyrix III 533/133=114 +Intel P2-266/440BX/PC66=117 +AMD-K6-III-400=135 +Intel Celeron-366/PC66=163 +AMD Duron-600/KT133=173 +AMD Athlon-700/KX133/PC133=202 +AMD Athlon-650/KX133=205 +Intel P3-500/GA-6BXDS/PC100=209 +Intel P3-550/Siemens/PC100=215 +Intel Celeron-300A@467/PC66=209 +Intel Celeron-300/PC66=146 +Intel P3-650/BX/PC100=238 +Intel P3-700/BX/PC100=211 +AMD Athlon-750/KT133/PC133=214 +AMD Duron-750/KT133=263 +Intel Celeron-566@1010=273 +VIA C3-1333/CN400=223 +AMD Duron-950/KT133=275 +AMD Duron-928 (9x103)/KT133=292 +AMD Duron-1100/SiS745/DDR333=477 +AMD Athlon XP-M 2500+/DDR333=548 +Intel P3-650@917/FSB140=310 +Intel P3-1000/PC133=218 +Intel P4-1600/i850=1115 +Intel P4-2000/i850/PC800=1245 +Intel P4-1800/i845G/DDR266=867 +Intel P4-2500/i845/DDR266=757 +Intel Pentium-M-1600/DDR266=830 +Intel Pentium-M 735/855PM/DDR400=971 +Intel P4-3066/i845PE/DDR266=1028 +Intel P4-2800/i875P/2Ch/DDR400=2056 +Intel P4-3200E/i875P/2Ch/DDR400=2342 +Intel P4-3600E/i915P/DDR2-533=2556 +Intel P4-3600E/i925X/DDR2-533=2844 +Intel Xeon-3800/E7525/DDR2-400=1635 +AMD Athlon64 3200+/1Ch/DDR400=1266 +AMD Athlon64 3800+/2Ch/DDR400=2375 +AMD Athlon64 FX-53/2Ch/DDR400=2166 +AMD Opteron 248/DDR266=947 +AMD Turion64 ML-34+=1071 +Intel Core 2 Duo E6700/DDR2-800=2894 +Transmeta Crusoe TM5800-1000=337 +2xIntel Xeon 5150/5000P/DDR2-667F=2919 +4xIntel Xeon MP 7040=1721 +AMD Phenom 9500=1795 +Intel Atom 230/945/DDR2-800=1682 +Intel Core i5-520M=5235 +Intel Core i7-860/DDR3-667/2CH=6506 +Intel Core i7-820QM=5424 +Intel Core i7-980X=9343 +Intel Core i7-3820/DDR3-1600/4CH=13366 + +[Benchmark_Disk_ReadBurst] +Fujitsu MPB3043ATU E/PIO=4.03 +Seagate ST38410A/PIO=4.33 +Maxtor 91021U2/PIO=4.61 +Maxtor 92041U4/PIO=4.82 +Quantum Fireball_TM2110S300X=6.83 +SEAGATE ST51080N=7.92 +Seagate ST31277A=8,37 +IBM DCAS-32160 S65A=8.65 +QUANTUM FIREBALL ST3.2A/PIO=14.74 +Seagate ST39102LW Cheetah=30.05 +IBM DJNA-370910/UDMA66=15.27 +Seagate ST34321A/UDMA33=21.03 +Seagate ST38421A=23.82 +Seagate ST34310A=23.88 +QUANTUM FIREBALL SE2.1A=26.43 +Maxtor 91021U2/UDMA33=29.13 +Maxtor 54098U8/UDMA33=29.5 +IBM DTTA-350430=29.7 +IBM-DPTA-371360=29.86 +Seagate ST320420A=47.3 +IBM-DJNA-371350=27.87 +IBM-DTLA-307030/ATA100=82.22 +SEAGATE Cheetah X15/RAID=137.08 +IBM Deskstar 60GXP/ATA100=81.98 +MAXTOR 4K020H1/ATA100=84.58 +Seagate ST317221A/UDMA66=42.03 +Maxtor 6E040L0=79.36 +Seagate ST380021A/ATA100=73.11 +HITACHI DK23EA-40=80.04 +WDC WD800JB/ATA100=85.71 +TOSHIBA MK4019GAX=83.60 +Maxtor MaxLine III SATA+NCQ=119.96 +ST312002 6AS=106.61 +Maxtor Atlas 10K5 73SCA=145.86 +WDC WD3200YS-01PGB0=167.33 +Hitachi HTE726040M9AT00=84.61 +Seagate ST3160827AS=120.88 +WDC WD5000AADS-00S9B0=122.87 +Hitachi HTS545032B9A=161.10 +Seagate ST1000DM003-9YN1=282.43 + +[Benchmark_Disk_ReadRandom] +Hitachi HTE726040M9AT00=22.82 +Maxtor Atlas 10K5 73SCA=31.61 +Seagate ST3160827AS=32.26 +FUJITSU MHV2080BH=17.79 +TOSHIBA MK8034GSX=18.12 +ST916082 1AS=22.27 +WDC WD5000AADS-00S9B0=24.58 +Hitachi HTS545032B9A=24.72 +Seagate ST1000DM003-9YN1=37.09 + +[Benchmark_Disk_RandomAccess] +SEAGATE ST51080N=20.96 +Quantum Fireball_TM2110S300X=20.74 +Seagate ST34321A/UDMA33=17.21 +Seagate ST38410A/PIO=17.17 +Seagate ST31277A=16.75 +Fujitsu MPB3043ATU E=16.18 +IBM DTTA-350430=16.5 +IBM DCAS-32160 S65A=15.95 +Maxtor 92041U4/PIO=15.81 +Seagate ST34310A=15.56 +Maxtor 91021U2/PIO=15.66 +Seagate ST38421A=15.71 +QUANTUM FIREBALL ST3.2A=15.50 +QUANTUM FIREBALL SE2.1A=14.94 +Maxtor 54098U8/UDMA33=13.77 +Seagate ST320420A=12.57 +IBM DJNA-370910/UDMA66=12.10 +Seagate ST39102LW Cheetah=8.78 +IBM-DPTA-371360=13.37 +IBM-DJNA-371350=13.38 +IBM-DTLA-307030/ATA100=12.44 +IBM-DTLA-307030/ATA100+AAM=22.34 +SEAGATE Cheetah X15/RAID=5.65 +IBM Deskstar 60GXP=12.70 +MAXTOR 4K020H1/ATA100=19.12 +Seagate ST317221A/UDMA66=16.60 +Maxtor 6E040L0=14.52 +Seagate ST380021A/ATA100=14.58 +HITACHI DK23EA-40=19.40 +WDC WD800JB/ATA100=13.61 +TOSHIBA MK4019GAX=18.61 +Maxtor MaxLine III SATA+NCQ=15.82 +ST312002 6AS=12.51 +Maxtor Atlas 10K5 73SCA=10.16 +WDC WD3200YS-01PGB0=13.16 +Hitachi HTE726040M9AT00=12.90 +Seagate ST3160827AS=11.65 +Seagate ST380215A=14.82 +WDC WD5000AADS-00S9B0=17.37 +Hitachi HTS545032B9A=22.16 +Seagate ST1000DM003-9YN1=15.53 + +[LogfileSettings] +COMP=1 +COMP_SP=1 +COMP_Name=1 +COMP_Os=1 +COMP_User=0 +CPU=1 +CPU_Name=1 +CPU_ID=1 +CPU_Vendor=1 +CPU_Stepping=1 +CPU_Type=1 +CPU_BrandID=1 +CPU_PN=1 +CPU_Clock=1 +CPU_MaxFreq=1 +CPU_CacheL1=1 +CPU_CacheL2=1 +CPU_TLB_I=1 +CPU_TLB_D=1 +CPU_Features=1 +CPU_PIROM=1 +MEM=1 +MEM_TotalSize=1 +MEM_Timing=1 +MEM_Row=1 +MEM_Row_Size=1 +MEM_Row_Type=1 +MEM_Row_Speed=1 +MEM_Row_Model=1 +MEM_Row_ECC=1 +MEM_Row_Date=1 +MEM_Row_SN=1 +MEM_Row_Cfg=1 +MEM_Row_Latency=1 +MEM_Row_Features=1 +MEM_Row_iFeatures=1 +BUS=1 +BUS_PCI=1 +BUS_PCI_DevName=1 +BUS_PCI_DevNumber=1 +BUS_PCI_Resources=1 +BUS_PCI_Features=1 +BUS_PCI_DevSpecific=1 +BUS_PCIX_Features=1 +BUS_PCIe_Features=1 +BUS_PCI_DRV_INFO=1 +BUS_EISA=1 +DMI=1 +DMI_0=1 +DMI_1=1 +DMI_2=1 +DMI_3=1 +DMI_4=1 +DMI_5=1 +DMI_6=1 +DMI_7=1 +DMI_8=1 +DMI_9=1 +DMI_10=1 +DMI_11=1 +DMI_12=1 +DMI_13=1 +DMI_14=1 +DMI_15=1 +DMI_16=1 +DMI_17=1 +DMI_18=1 +DMI_19=1 +DMI_20=1 +DMI_21=1 +DMI_22=1 +DMI_23=1 +DMI_24=1 +DMI_25=1 +DMI_26=1 +DMI_27=1 +DMI_28=1 +DMI_29=1 +DMI_30=1 +DMI_31=1 +DMI_32=1 +DMI_33=1 +DMI_34=1 +DMI_35=1 +DMI_36=1 +DMI_37=1 +DMI_38=1 +DMI_39=1 +DMI_129=1 +DMI_130=1 +DMI_131=1 +VIDEO=1 +VIDEO_Chipset=1 +VIDEO_Memory=1 +VIDEO_Card=1 +VIDEO_Bus=1 +VIDEO_RAMDAC=1 +VIDEO_BIOSver=1 +VIDEO_Clock=1 +VIDEO_HWID=1 +VIDEO_DRV_INFO=1 +VIDEO_DirectX=1 +MON=1 +MON_Name=1 +MON_SN=1 +MON_Date=1 +MON_Dimensions=1 +MON_DisplayType=1 +MON_InputSignal=1 +MON_Gamma=1 +MON_DPMSinput=1 +MON_DPMSmodes=1 +MOBO=1 +MOBO_Model=1 +MOBO_Chipset=1 +MOBO_CompName=1 +MOBO_MachineType=1 +MOBO_Slots=1 +MOBO_BIOS_Manuf=1 +MOBO_BIOS_Date=1 +MOBO_PNP_Devs=1 +MOBO_PNP_Nodes=1 +MOBO_ACPI_Devs=1 +MOBO_ACPI_Enum=1 +DRIVE=1 +DRIVE_IDE=1 +DRIVE_IDE_Ctrller=1 +DRIVE_IDE_Channel=1 +DRIVE_IDE_Model=1 +DRIVE_IDE_Rev=1 +DRIVE_IDE_SN=1 +DRIVE_IDE_Capacity=1 +DRIVE_IDE_Geometry=1 +DRIVE_IDE_Cache=1 +DRIVE_IDE_Xfer=1 +DRIVE_IDE_BasicCapab=1 +DRIVE_IDE_ATA2Capab=1 +DRIVE_IDE_SMART=1 +DRIVE_SCSI=1 +DRIVE_SCSI_ID=1 +DRIVE_SCSI_Desc=1 +DRIVE_SCSI_Class=1 +DRIVE_Floppy=1 +NETWORK=1 +NETWORK_HWID=1 +NETWORK_DRV_INFO=1 +AUDIO=1 +AUDIO_DRV_INFO=1 +AUDIO_HWID=1 +PORTS=1 +BUS_USB=1 +BUS_USB_DRV_INFO=1 +BATTERY=1 +SENSORS=1 + +[Settings] +AC97CodecID=1 +AcpiEnum=0 +AcpiEval=1 +AutoUpdate=0 +AutoUpdateBetaDisable=1 +BusClkPolling=1 +CpuClkFromBusClk=1 +DebugMode=0 +DefReportType=5 +EC=1 +FlushBuffers=1 +GPUI2C=1 +GPUI2CADL=0 +GPUI2CBusExclude=00000000 +GPUI2CNVAPI=1 +GPUI2Ccaching=1 +HighestIdeAddress=0 +IoctlKernel=0 +KeepTheme=0 +LargeFonts=0 +MinimalizeMainWnd=0 +MinimalizeSensors=0 +OpenSensors=0 +OpenSystemSummary=0 +PCIdirect=1 +PersistentDriver=0 +RememberPreferences=1 +SMBus=1 +SMBusAdrExclude=11111111111111110000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010000000000000000000000 +SWSMI=1 +SensorsSM=1 +ShowWelcomeAndProgress=0 +SkipProblematicPciDev=0 +TPM=0 +TempScale=C +UseHPET=1 +WakeGPUs=1 +iMEsupport=1 +MinimizeGraphs=1 +SensorRowShading=1 +SensorsTopmost=0 +DecimalSeparator=. +ThousandsSeparator=, +CsvSeparator=, +TextButtons=0 diff --git a/.bin/Scripts/Copy WizardKit.cmd b/.bin/Scripts/Copy WizardKit.cmd index 74f5b2f9..cc20efe1 100644 --- a/.bin/Scripts/Copy WizardKit.cmd +++ b/.bin/Scripts/Copy WizardKit.cmd @@ -1,152 +1,152 @@ -:: Wizard Kit: Copy Kit :: -@echo off - -:Init -setlocal EnableDelayedExpansion -title Wizard Kit: Tools Copier -color 1b -echo Initializing... -call :CheckFlags %* -call :FindBin -call :SetTitle Tools Copier - -:SetVariables -rem Set variables using settings\main.py file -set "SETTINGS=%bin%\Scripts\settings\main.py" -for %%v in (ARCHIVE_PASSWORD KIT_NAME_FULL) do ( - set "var=%%v" - for /f "tokens=* usebackq" %%f in (`findstr "!var!=" %SETTINGS%`) do ( - set "_v=%%f" - set "_v=!_v:*'=!" - set "%%v=!_v:~0,-1!" - ) -) -rem Set ARCH to 32 as a gross assumption and check for x86_64 status -set ARCH=32 -if /i "%PROCESSOR_ARCHITECTURE%" == "AMD64" set "ARCH=64" -set "SEVEN_ZIP=%bin%\7-Zip\7za.exe" -set "CON=%bin%\ConEmu\ConEmu.exe" -set "FASTCOPY=%bin%\FastCopy\FastCopy.exe" -if %ARCH% equ 64 ( - set "SEVEN_ZIP=%bin%\7-Zip\7za64.exe" - set "CON=%bin%\ConEmu\ConEmu64.exe" - set "FASTCOPY=%bin%\FastCopy\FastCopy64.exe" -) -set "fastcopy_args=/cmd=diff /no_ui /auto_close" -rem Set %client_dir% -call "%bin%\Scripts\init_client_dir.cmd" -pushd "%bin%\.." -set "source=%cd%" -popd -set "dest=%client_dir%\Tools" - -:RelaunchInConEmu -if not defined IN_CONEMU ( - if not defined L_NCMD ( - set "con_args=-new_console:n" - rem If in DEBUG state then force ConEmu to stay open - if defined DEBUG (set "con_args=!con_args! -new_console:c") - set IN_CONEMU=True - start "" "%CON%" -run ""%~0" %*" !con_args! || goto ErrorUnknown - exit /b 0 - ) -) -:CopyBin -echo Copying .bin... -mkdir "%dest%\.bin" >nul 2>&1 -attrib +h "%dest%\.bin" -set _sources="%bin%\7-Zip" -set _sources=%_sources% "%bin%\ConEmu" -set _sources=%_sources% "%bin%\FastCopy" -set _sources=%_sources% "%bin%\HWiNFO" -set _sources=%_sources% "%bin%\Python" -set _sources=%_sources% "%bin%\Scripts" -start "" /wait "%fastcopy%" %fastcopy_args% %_sources% /to="%dest%\.bin\" - -:CopyCBin -echo Copying .cbin... -mkdir "%dest%\.cbin" >nul 2>&1 -attrib +h "%dest%\.cbin" -start "" /wait "%fastcopy%" %fastcopy_args% %cbin%\* /to="%dest%\.cbin\" - -:CopyMainData -echo Copying Main Kit... -set _sources="%source%\Data Transfers" -set _sources=%_sources% "%source%\Diagnostics" -set _sources=%_sources% "%source%\Drivers" -set _sources=%_sources% "%source%\Installers" -set _sources=%_sources% "%source%\Misc" -set _sources=%_sources% "%source%\Repairs" -set _sources=%_sources% "%source%\Uninstallers" -set _sources=%_sources% "%source%\Activate Windows.cmd" -set _sources=%_sources% "%source%\Enter SafeMode.cmd" -set _sources=%_sources% "%source%\Exit SafeMode.cmd" -set _sources=%_sources% "%source%\LICENSE.txt" -set _sources=%_sources% "%source%\README.md" -set _sources=%_sources% "%source%\System Checklist.cmd" -set _sources=%_sources% "%source%\System Diagnostics.cmd" -set _sources=%_sources% "%source%\User Checklist.cmd" -start "" /wait "%fastcopy%" %fastcopy_args% /exclude="Snappy Driver Installer.cmd;*.exe" %_sources% /to="%dest%\" -start "" /wait "%fastcopy%" %fastcopy_args% "%source%\Installers\Extras\Office\Adobe Reader DC.exe" /to="%dest%\Installers\Extras\Office\" - -:Ninite -echo Extracting Ninite installers... -"%SEVEN_ZIP%" x "%cbin%\_Ninite.7z" -aos -bso0 -bse0 -bsp0 -p%ARCHIVE_PASS% -o"%dest%\Installers\Extras" || goto Abort - -:OpenFolder -start "" explorer "%dest%" -goto Exit - -:: Functions :: -:CheckFlags -rem Loops through all arguments to check for accepted flags -set DEBUG= -for %%f in (%*) do ( - if /i "%%f" == "/DEBUG" (@echo on & set "DEBUG=/DEBUG") -) -@exit /b 0 - -:FindBin -rem Checks the current directory and all parents for the ".bin" folder -rem NOTE: Has not been tested for UNC paths -set bin= -pushd "%~dp0" -:FindBinInner -if exist ".bin" (goto FindBinDone) -if "%~d0\" == "%cd%" (popd & @exit /b 1) -cd .. -goto FindBinInner -:FindBinDone -set "bin=%cd%\.bin" -set "cbin=%cd%\.cbin" -popd -@exit /b 0 - -:SetTitle -rem Sets title using KIT_NAME_FULL from settings\main.py -set "window_title=%*" -if not defined window_title set "window_title=Launcher" -set "window_title=%KIT_NAME_FULL%: %window_title%" -title %window_title% -@exit /b 0 - -:: Errors :: -:ErrorNoBin -echo. -echo ERROR: ".bin" folder not found. -goto Abort - -:Abort -color 4e -echo Aborted. -echo Press any key to exit... -pause>nul -color -rem Set errorlevel to 1 by calling color incorrectly -color 00 -goto Exit - -:: Cleanup and exit :: -:Exit -endlocal -exit /b %errorlevel% +:: Wizard Kit: Copy Kit :: +@echo off + +:Init +setlocal EnableDelayedExpansion +title Wizard Kit: Tools Copier +color 1b +echo Initializing... +call :CheckFlags %* +call :FindBin +call :SetTitle Tools Copier + +:SetVariables +rem Set variables using settings\main.py file +set "SETTINGS=%bin%\Scripts\settings\main.py" +for %%v in (ARCHIVE_PASSWORD KIT_NAME_FULL) do ( + set "var=%%v" + for /f "tokens=* usebackq" %%f in (`findstr "!var!=" %SETTINGS%`) do ( + set "_v=%%f" + set "_v=!_v:*'=!" + set "%%v=!_v:~0,-1!" + ) +) +rem Set ARCH to 32 as a gross assumption and check for x86_64 status +set ARCH=32 +if /i "%PROCESSOR_ARCHITECTURE%" == "AMD64" set "ARCH=64" +set "SEVEN_ZIP=%bin%\7-Zip\7za.exe" +set "CON=%bin%\ConEmu\ConEmu.exe" +set "FASTCOPY=%bin%\FastCopy\FastCopy.exe" +if %ARCH% equ 64 ( + set "SEVEN_ZIP=%bin%\7-Zip\7za64.exe" + set "CON=%bin%\ConEmu\ConEmu64.exe" + set "FASTCOPY=%bin%\FastCopy\FastCopy64.exe" +) +set "fastcopy_args=/cmd=diff /no_ui /auto_close" +rem Set %client_dir% +call "%bin%\Scripts\init_client_dir.cmd" +pushd "%bin%\.." +set "source=%cd%" +popd +set "dest=%client_dir%\Tools" + +:RelaunchInConEmu +if not defined IN_CONEMU ( + if not defined L_NCMD ( + set "con_args=-new_console:n" + rem If in DEBUG state then force ConEmu to stay open + if defined DEBUG (set "con_args=!con_args! -new_console:c") + set IN_CONEMU=True + start "" "%CON%" -run ""%~0" %*" !con_args! || goto ErrorUnknown + exit /b 0 + ) +) +:CopyBin +echo Copying .bin... +mkdir "%dest%\.bin" >nul 2>&1 +attrib +h "%dest%\.bin" +set _sources="%bin%\7-Zip" +set _sources=%_sources% "%bin%\ConEmu" +set _sources=%_sources% "%bin%\FastCopy" +set _sources=%_sources% "%bin%\HWiNFO" +set _sources=%_sources% "%bin%\Python" +set _sources=%_sources% "%bin%\Scripts" +start "" /wait "%fastcopy%" %fastcopy_args% %_sources% /to="%dest%\.bin\" + +:CopyCBin +echo Copying .cbin... +mkdir "%dest%\.cbin" >nul 2>&1 +attrib +h "%dest%\.cbin" +start "" /wait "%fastcopy%" %fastcopy_args% %cbin%\* /to="%dest%\.cbin\" + +:CopyMainData +echo Copying Main Kit... +set _sources="%source%\Data Transfers" +set _sources=%_sources% "%source%\Diagnostics" +set _sources=%_sources% "%source%\Drivers" +set _sources=%_sources% "%source%\Installers" +set _sources=%_sources% "%source%\Misc" +set _sources=%_sources% "%source%\Repairs" +set _sources=%_sources% "%source%\Uninstallers" +set _sources=%_sources% "%source%\Activate Windows.cmd" +set _sources=%_sources% "%source%\Enter SafeMode.cmd" +set _sources=%_sources% "%source%\Exit SafeMode.cmd" +set _sources=%_sources% "%source%\LICENSE.txt" +set _sources=%_sources% "%source%\README.md" +set _sources=%_sources% "%source%\System Checklist.cmd" +set _sources=%_sources% "%source%\System Diagnostics.cmd" +set _sources=%_sources% "%source%\User Checklist.cmd" +start "" /wait "%fastcopy%" %fastcopy_args% /exclude="Snappy Driver Installer.cmd;*.exe" %_sources% /to="%dest%\" +start "" /wait "%fastcopy%" %fastcopy_args% "%source%\Installers\Extras\Office\Adobe Reader DC.exe" /to="%dest%\Installers\Extras\Office\" + +:Ninite +echo Extracting Ninite installers... +"%SEVEN_ZIP%" x "%cbin%\_Ninite.7z" -aos -bso0 -bse0 -bsp0 -p%ARCHIVE_PASS% -o"%dest%\Installers\Extras" || goto Abort + +:OpenFolder +start "" explorer "%dest%" +goto Exit + +:: Functions :: +:CheckFlags +rem Loops through all arguments to check for accepted flags +set DEBUG= +for %%f in (%*) do ( + if /i "%%f" == "/DEBUG" (@echo on & set "DEBUG=/DEBUG") +) +@exit /b 0 + +:FindBin +rem Checks the current directory and all parents for the ".bin" folder +rem NOTE: Has not been tested for UNC paths +set bin= +pushd "%~dp0" +:FindBinInner +if exist ".bin" (goto FindBinDone) +if "%~d0\" == "%cd%" (popd & @exit /b 1) +cd .. +goto FindBinInner +:FindBinDone +set "bin=%cd%\.bin" +set "cbin=%cd%\.cbin" +popd +@exit /b 0 + +:SetTitle +rem Sets title using KIT_NAME_FULL from settings\main.py +set "window_title=%*" +if not defined window_title set "window_title=Launcher" +set "window_title=%KIT_NAME_FULL%: %window_title%" +title %window_title% +@exit /b 0 + +:: Errors :: +:ErrorNoBin +echo. +echo ERROR: ".bin" folder not found. +goto Abort + +:Abort +color 4e +echo Aborted. +echo Press any key to exit... +pause>nul +color +rem Set errorlevel to 1 by calling color incorrectly +color 00 +goto Exit + +:: Cleanup and exit :: +:Exit +endlocal +exit /b %errorlevel% diff --git a/.bin/Scripts/Launch.cmd b/.bin/Scripts/Launch.cmd index fd72d374..5d1e1093 100644 --- a/.bin/Scripts/Launch.cmd +++ b/.bin/Scripts/Launch.cmd @@ -1,496 +1,496 @@ -:: Wizard Kit: Wrapper for launching programs and scripts. -:: -:: Some features: -:: * If the OS is 64-bit then the WorkingDir is scanned for a 64-bit version of the programs -:: * Allows for centralized terminal emulation settings management -:: * Allows for smaller "launcher" scripts to be used as they will rely on this script. - -@echo off -if defined DEBUG (@echo on) - -:Init -setlocal EnableDelayedExpansion -title Wizard Kit: Launcher -pushd "%~dp0" -call :FindBin -call :DeQuote L_ITEM -call :DeQuote L_PATH -call :DeQuote L_TYPE - -:SetVariables -rem Set variables using settings\main.py file -set "SETTINGS=%bin%\Scripts\settings\main.py" -for %%v in (ARCHIVE_PASSWORD KIT_NAME_FULL OFFICE_SERVER_IP QUICKBOOKS_SERVER_IP) do ( - set "var=%%v" - for /f "tokens=* usebackq" %%f in (`findstr "!var!=" %SETTINGS%`) do ( - set "_v=%%f" - set "_v=!_v:*'=!" - set "%%v=!_v:~0,-1!" - ) -) -rem Set ARCH to 32 as a gross assumption and check for x86_64 status -set ARCH=32 -if /i "%PROCESSOR_ARCHITECTURE%" == "AMD64" set "ARCH=64" -set "SEVEN_ZIP=%bin%\7-Zip\7za.exe" -set "CON=%bin%\ConEmu\ConEmu.exe" -set "FASTCOPY=%bin%\FastCopy\FastCopy.exe" -set "POWERSHELL=%systemroot%\system32\WindowsPowerShell\v1.0\powershell.exe" -set "PYTHON=%bin%\Python\x32\python.exe" -if %ARCH% equ 64 ( - set "SEVEN_ZIP=%bin%\7-Zip\7za64.exe" - set "CON=%bin%\ConEmu\ConEmu64.exe" - set "FASTCOPY=%bin%\FastCopy\FastCopy64.exe" - set "PYTHON=%bin%\Python\x64\python.exe" -) - -:UpdateTitle -rem Sets title using KIT_NAME_FULL from settings\main.py (unless %window_title% already set) -if defined window_title ( - title %window_title% -) else ( - set "window_title=%*" - if not defined window_title set "window_title=Launcher" - set "window_title=%KIT_NAME_FULL%: %window_title%" - title %window_title% -) - -:CheckUsage -rem Check for empty passed variables -if not defined L_TYPE (goto Usage) -if not defined L_PATH (goto Usage) -if not defined L_ITEM (goto Usage) -rem Assume if not "True" then False (i.e. undefine variable) -if /i not "%L_ELEV%" == "True" (set "L_ELEV=") -if /i not "%L_NCMD%" == "True" (set "L_NCMD=") -if /i not "%L__CLI%" == "True" (set "L__CLI=") - -:RelaunchInConEmu -set RELOAD_IN_CONEMU=True -if defined ConEmuBuild set "RELOAD_IN_CONEMU=" -if defined L_NCMD set "RELOAD_IN_CONEMU=" -if "%L_TYPE%" == "Executable" set "RELOAD_IN_CONEMU=" -if "%L_TYPE%" == "PSScript" set "RELOAD_IN_CONEMU=" -if "%L_TYPE%" == "PyScript" set "RELOAD_IN_CONEMU=" - -if defined RELOAD_IN_CONEMU ( - set "con_args=-new_console:n" - rem If in DEBUG state then force ConEmu to stay open - if defined DEBUG (set "con_args=!con_args! -new_console:c") - start "" "%CON%" -run ""%~0" %*" !con_args! || goto ErrorUnknown - exit /b 0 -) - -:CheckLaunchType -rem Jump to the selected launch type or show usage -if /i "%L_TYPE%" == "Executable" (goto LaunchExecutable) -if /i "%L_TYPE%" == "Folder" (goto LaunchFolder) -if /i "%L_TYPE%" == "Office" (goto LaunchOffice) -if /i "%L_TYPE%" == "PSScript" (goto LaunchPSScript) -if /i "%L_TYPE%" == "PyScript" (goto LaunchPyScript) -if /i "%L_TYPE%" == "QuickBooks" (goto LaunchQuickBooksSetup) -goto Usage - -:LaunchExecutable -rem Prep -call :ExtractOrFindPath || goto ErrorProgramNotFound - -rem Check for 64-bit prog (if running on 64-bit system) -set "prog=%_path%\%L_ITEM%" -if %ARCH% equ 64 ( - if exist "%_path%\%L_ITEM:.=64.%" set "prog=%_path%\%L_ITEM:.=64.%" -) -if not exist "%prog%" goto ErrorProgramNotFound - -rem Run -popd && pushd "%_path%" -if defined L__CLI goto LaunchExecutableCLI -if defined L_ELEV ( - goto LaunchExecutableElev -) else ( - goto LaunchExecutableUser -) - -:LaunchExecutableCLI -rem Prep -set "con_args=-new_console:n" -if defined DEBUG (set "con_args=%con_args% -new_console:c") -if defined L_ELEV (set "con_args=%con_args% -new_console:a") - -rem Run -start "" "%CON%" -run "%prog%" %L_ARGS% %con_args% || goto ErrorUnknown -goto Exit - -:LaunchExecutableElev -rem Prep -call :DeQuote prog -call :DeQuote L_ARGS - -rem Create VB script -mkdir "%bin%\tmp" 2>nul -echo Set UAC = CreateObject^("Shell.Application"^) > "%bin%\tmp\Elevate.vbs" -echo UAC.ShellExecute "%prog%", "%L_ARGS%", "", "runas", 1 >> "%bin%\tmp\Elevate.vbs" - -rem Run -"%systemroot%\System32\cscript.exe" //nologo "%bin%\tmp\Elevate.vbs" || goto ErrorUnknown -goto Exit - -:LaunchExecutableUser -rem Run -start "" "%prog%" %L_ARGS% || goto ErrorUnknown -goto Exit - -:LaunchFolder -rem Prep -call :ExtractOrFindPath || goto ErrorProgramNotFound - -rem Run -start "" "explorer.exe" "%_path%" || goto ErrorUnknown -goto Exit - -:LaunchOffice -call "%bin%\Scripts\init_client_dir.cmd" /Office -set "_odt=False" -if %L_PATH% equ 2013 (set "_odt=True") -if %L_PATH% equ 2016 (set "_odt=True") -if "%_odt%" == "True" ( - goto LaunchOfficeODT -) else ( - goto LaunchOfficeSetup -) - -:LaunchOfficeODT -rem Prep -set "args=-aoa -bso0 -bse0 -bsp0 -p%ARCHIVE_PASSWORD%" -set "config=%L_ITEM%" -set "dest=%client_dir%\Office\%L_PATH%" -set "odt_exe=%L_PATH%\setup.exe" -set "source=%cbin%\_Office.7z" - -rem Extract -if not exist "%source%" (goto ErrorODTSourceNotFound) -"%SEVEN_ZIP%" e "%source%" %args% -o"%dest%" %odt_exe% %config% || exit /b 1 -"%systemroot%\System32\ping.exe" -n 2 127.0.0.1>nul - -rem Verify -if not exist "%dest%\setup.exe" (goto ErrorODTSourceNotFound) -if not exist "%dest%\%config%" (goto ErrorODTSourceNotFound) -pushd "%dest%" - -rem Run -rem # The line below jumps to ErrorUnknown even when it runs correctly?? -rem start "" "setup.exe" /configure %L_ITEM% || popd & goto ErrorUnknown -rem # Going to assume it extracted correctly and blindly start setup.exe -start "" "setup.exe" /configure %config% -popd -goto Exit - -:LaunchOfficeSetup -rem Prep -set "fastcopy_args=/cmd=diff /no_ui /auto_close" -set "product=%L_PATH%\%L_ITEM%" -set "product_name=%L_ITEM%" -call :GetBasename product_name || goto ErrorBasename -set "source=\\%OFFICE_SERVER_IP%\Office\%product%" -set "dest=%client_dir%\Office" - -rem Verify -if not exist "%source%" (goto ErrorOfficeSourceNotFound) - -rem Copy -echo Copying setup file(s) for %product_name%... -start "" /wait "%FASTCOPY%" %fastcopy_args% "%source%" /to="%dest%\" - -rem Run -if exist "%dest%\%product_name%\setup.exe" ( - start "" "%dest%\%product_name%\setup.exe" || goto ErrorUnknown -) else if "%product_name:~-3,3%" == "exe" ( - start "" "%dest%\%product_name%" || goto ErrorUnknown -) else if "%product_name:~-3,3%" == "msi" ( - start "" "%dest%\%product_name%" || goto ErrorUnknown -) else ( - rem Office source not supported by this script - goto ErrorOfficeUnsupported -) -goto Exit - -:LaunchPSScript -rem Prep -call :ExtractOrFindPath || goto ErrorProgramNotFound -set "script=%_path%\%L_ITEM%" -set "ps_args=-ExecutionPolicy Bypass -NoProfile" - -rem Verify -if not exist "%script%" goto ErrorScriptNotFound - -rem Run -popd && pushd "%_path%" -if defined L_ELEV ( - goto LaunchPSScriptElev -) else ( - goto LaunchPSScriptUser -) - -:LaunchPSScriptElev -rem Prep -call :DeQuote script - -rem Create VB script -mkdir "%bin%\tmp" 2>nul -echo Set UAC = CreateObject^("Shell.Application"^) > "%bin%\tmp\Elevate.vbs" -if defined L_NCMD ( - rem use Powershell's window instead of %CON% - echo UAC.ShellExecute "%POWERSHELL%", "%ps_args% -File "%script%"", "", "runas", 3 >> "%bin%\tmp\Elevate.vbs" -) else ( - echo UAC.ShellExecute "%CON%", "-run %POWERSHELL% %ps_args% -File "%script%" -new_console:n", "", "runas", 1 >> "%bin%\tmp\Elevate.vbs" -) - -rem Run -"%systemroot%\System32\cscript.exe" //nologo "%bin%\tmp\Elevate.vbs" || goto ErrorUnknown -goto Exit - -:LaunchPSScriptUser -rem Run -if defined L_NCMD ( - start "" "%POWERSHELL%" %ps_args% -File "%script%" || goto ErrorUnknown -) else ( - start "" "%CON%" -run "%POWERSHELL%" %ps_args% -File "%script%" -new_console:n || goto ErrorUnknown -) -goto Exit - -:LaunchPyScript -rem Prep -call :ExtractOrFindPath || goto ErrorProgramNotFound -set "script=%_path%\%L_ITEM%" - -rem Verify -if not exist "%script%" goto ErrorScriptNotFound - -rem Run -if defined L_ELEV ( - goto LaunchPyScriptElev -) else ( - goto LaunchPyScriptUser -) - -:LaunchPyScriptElev -rem Prep -call :DeQuote script - -rem Create VB script -mkdir "%bin%\tmp" 2>nul -echo Set UAC = CreateObject^("Shell.Application"^) > "%bin%\tmp\Elevate.vbs" -if defined L_NCMD ( - echo UAC.ShellExecute "%PYTHON%", "%script%", "", "runas", 3 >> "%bin%\tmp\Elevate.vbs" -) else ( - echo UAC.ShellExecute "%CON%", "-run %PYTHON% %script% -new_console:n", "", "runas", 1 >> "%bin%\tmp\Elevate.vbs" -) - -rem Run -"%systemroot%\System32\cscript.exe" //nologo "%bin%\tmp\Elevate.vbs" || goto ErrorUnknown -goto Exit - -:LaunchPyScriptUser -if defined L_NCMD ( - start "" "%PYTHON%" "%script%" || goto ErrorUnknown -) else ( - start "" "%CON%" -run "%PYTHON%" "%script%" -new_console:n || goto ErrorUnknown -) -goto Exit - -:LaunchQuickBooksSetup -rem Prep -call "%bin%\Scripts\init_client_dir.cmd" /QuickBooks -set "fastcopy_args=/cmd=diff /no_ui /auto_close" -set "product=%L_PATH%\%L_ITEM%" -set "product_name=%L_ITEM%" -call :GetBasename product_name || goto ErrorBasename -set "source=\\%QUICKBOOKS_SERVER_IP%\QuickBooks\%product%" -set "dest=%client_dir%\QuickBooks" - -rem Verify -if not exist "%source%" (goto ErrorQuickBooksSourceNotFound) - -rem Copy -echo Copying setup file(s) for %L_ITEM%... -start "" /wait "%FASTCOPY%" %fastcopy_args% "%source%" /to="%dest%\" - -rem Run -if exist "%dest%\%product_name%\Setup.exe" ( - pushd "%dest%\%product_name%" - start "" "%dest%\%product_name%\Setup.exe" || goto ErrorUnknown - popd -) else ( - rem QuickBooks source not supported by this script - goto ErrorQuickBooksUnsupported -) -goto Exit - -:Usage -echo. -echo.Usage (via defined variables): -echo. L_TYPE L_PATH L_ITEM L_ARGS -echo. Executable Working Dir Program Args [L_7ZIP] [L_ELEV] [L__CLI] -echo. Folder Folder '.' [L_7ZIP] -echo. Office Year Product [L_7ZIP] -echo. PSScript Scripts Script [L_7ZIP] [L_ELEV] [L_NCMD] -echo. PyScript Scripts Script [L_7ZIP] [L_ELEV] [L_NCMD] -echo. QuickBooks Year Product [L_7ZIP] -echo. -echo.L_7ZIP: Extra arguments for 7-Zip (in the :ExtractCBin label) -echo.L_ELEV: Elevate to run as Admin -echo.L_NCMD: Do not run script inside ConEmu (i.e. use the native window) -echo.L__CLI: Run executable in ConEmu -echo. -goto Abort - -:: Functions :: -:DeQuote -rem Code taken from http://ss64.com/nt/syntax-dequote.html -if not defined %1 (@exit /b 1) -for /f "delims=" %%a in ('echo %%%1%%') do set %1=%%~a -@exit /b 0 - -:ExtractCBin -rem Extract %cbin% archive into %bin% -echo Extracting "%L_PATH%"... -set "source=%cbin%\%L_PATH%.7z" -set "dest=%bin%\%L_PATH%" -set "args=-aos -bso0 -bse0 -bsp0 -p%ARCHIVE_PASSWORD%" -if defined DEBUG (set "args=-aos -p%ARCHIVE_PASSWORD%") -"%SEVEN_ZIP%" x "%source%" %args% -o"%dest%" %L_7ZIP% || exit /b 1 -ping.exe -n 2 127.0.0.1>nul -exit /b 0 - -:FindBin -rem Checks the current directory and all parents for the ".bin" folder -rem NOTE: Has not been tested for UNC paths -set bin= -pushd "%~dp0" -:FindBinInner -if exist ".bin" (goto FindBinDone) -if "%~d0\" == "%cd%" (popd & @exit /b 1) -cd .. -goto FindBinInner -:FindBinDone -set "bin=%cd%\.bin" -set "cbin=%cd%\.cbin" -popd -@exit /b 0 - -:GetBasename -rem Loop over passed variable to remove all text left of the last '\' character -rem NOTE: This function should be called as 'call :GetBasename VarName || goto ErrorBasename' to catch variables that become empty. -for /f "delims=" %%a in ('echo %%%1%%') do (set "_tmp=%%~a") -:GetBasenameInner -set "_tmp=%_tmp:*\=%" -if not defined _tmp (@exit /b 1) -if not "%_tmp%" == "%_tmp:*\=%" (goto GetBasenameInner) -:GetBasenameDone -set "%1=%_tmp%" -@exit /b 0 - -:ExtractOrFindPath -rem Test L_PATH in the following order: -rem 1: %cbin%\L_PATH.7z (which will be extracted to %bin%\L_PATH) -rem 2: %bin%\L_PATH -rem 3. %L_PATH% (i.e. treat L_PATH as an absolute path) -rem NOTE: This function should be called as 'call :ExtractOrFindPath || goto ErrorProgramNotFound' to catch invalid paths. -set _path= -if exist "%cbin%\%L_PATH%.7z" ( - call :ExtractCBin -) else if exist "%cbin%\%L_PATH%\%L_ITEM:~0,-4%.7z" ( - call :ExtractCBin -) -if exist "%bin%\%L_PATH%" (set "_path=%bin%\%L_PATH%") -if not defined _path (set "_path=%L_PATH%") -rem Raise error if path is still not available -if not exist "%_path%" (exit /b 1) -exit /b 0 - -:: Errors :: -:ErrorBasename -echo. -echo ERROR: GetBasename resulted in an empty variable. -goto Abort - -:ErrorNoBin -echo. -echo ERROR: ".bin" folder not found. -goto Abort - -:ErrorODTSourceNotFound -echo. -echo ERROR: Office Deployment Tool source not found. -goto Abort - -:ErrorOfficeSourceNotFound -echo. -echo ERROR: Office source "%L_ITEM%" not found. -goto Abort - -:ErrorOfficeUnsupported -rem Source is not an executable nor is a folder with a setup.exe file inside. Open explorer to local setup file(s) instead. -echo. -echo ERROR: Office version not supported by this script. -start "" "explorer.exe" "%client_dir%\Office" -goto Abort - -:ErrorQuickBooksSourceNotFound -echo. -echo ERROR: QuickBooks source "%L_ITEM%" not found. -goto Abort - -:ErrorQuickBooksUnsupported -rem Source is not an executable nor is a folder with a setup.exe file inside. Open explorer to local setup file(s) instead. -echo. -echo ERROR: QuickBooks version not supported by this script. -start "" "explorer.exe" "%client_dir%\QuickBooks" -goto Abort - -:ErrorProgramNotFound -echo. -echo ERROR: Program "%prog%" not found. -goto Abort - -:ErrorScriptNotFound -echo. -echo ERROR: Script "%script%" not found. -goto Abort - -:ErrorUnknown -echo. -echo ERROR: Unknown error encountered. -goto Abort - -:Abort -rem Handle color theme for both the native console and ConEmu -if defined ConEmuBuild ( - color c4 -) else ( - color 4e -) -echo Aborted. -echo. -echo DETAILS: L_TYPE: %L_TYPE% -echo. L_PATH: %L_PATH% -echo. L_ITEM: %L_ITEM% -echo. L_ARGS: %L_ARGS% -echo. L_7ZIP: %L_7ZIP% -echo. L_ELEV: %L_ELEV% -echo. L_NCMD: %L_NCMD% -echo. L__CLI: %L__CLI% -echo. CON: %CON% -echo. DEBUG: %DEBUG% -echo. PYTHON: %PYTHON% -echo Press any key to exit... -pause>nul -rem reset color and reset errorlevel to 0 -rem NOTE: This is done to avoid causing a ErrorLaunchCMD in the launcher.cmd -color -goto Exit - -:: Cleanup and exit :: -:Exit -popd -endlocal +:: Wizard Kit: Wrapper for launching programs and scripts. +:: +:: Some features: +:: * If the OS is 64-bit then the WorkingDir is scanned for a 64-bit version of the programs +:: * Allows for centralized terminal emulation settings management +:: * Allows for smaller "launcher" scripts to be used as they will rely on this script. + +@echo off +if defined DEBUG (@echo on) + +:Init +setlocal EnableDelayedExpansion +title Wizard Kit: Launcher +pushd "%~dp0" +call :FindBin +call :DeQuote L_ITEM +call :DeQuote L_PATH +call :DeQuote L_TYPE + +:SetVariables +rem Set variables using settings\main.py file +set "SETTINGS=%bin%\Scripts\settings\main.py" +for %%v in (ARCHIVE_PASSWORD KIT_NAME_FULL OFFICE_SERVER_IP QUICKBOOKS_SERVER_IP) do ( + set "var=%%v" + for /f "tokens=* usebackq" %%f in (`findstr "!var!=" %SETTINGS%`) do ( + set "_v=%%f" + set "_v=!_v:*'=!" + set "%%v=!_v:~0,-1!" + ) +) +rem Set ARCH to 32 as a gross assumption and check for x86_64 status +set ARCH=32 +if /i "%PROCESSOR_ARCHITECTURE%" == "AMD64" set "ARCH=64" +set "SEVEN_ZIP=%bin%\7-Zip\7za.exe" +set "CON=%bin%\ConEmu\ConEmu.exe" +set "FASTCOPY=%bin%\FastCopy\FastCopy.exe" +set "POWERSHELL=%systemroot%\system32\WindowsPowerShell\v1.0\powershell.exe" +set "PYTHON=%bin%\Python\x32\python.exe" +if %ARCH% equ 64 ( + set "SEVEN_ZIP=%bin%\7-Zip\7za64.exe" + set "CON=%bin%\ConEmu\ConEmu64.exe" + set "FASTCOPY=%bin%\FastCopy\FastCopy64.exe" + set "PYTHON=%bin%\Python\x64\python.exe" +) + +:UpdateTitle +rem Sets title using KIT_NAME_FULL from settings\main.py (unless %window_title% already set) +if defined window_title ( + title %window_title% +) else ( + set "window_title=%*" + if not defined window_title set "window_title=Launcher" + set "window_title=%KIT_NAME_FULL%: %window_title%" + title %window_title% +) + +:CheckUsage +rem Check for empty passed variables +if not defined L_TYPE (goto Usage) +if not defined L_PATH (goto Usage) +if not defined L_ITEM (goto Usage) +rem Assume if not "True" then False (i.e. undefine variable) +if /i not "%L_ELEV%" == "True" (set "L_ELEV=") +if /i not "%L_NCMD%" == "True" (set "L_NCMD=") +if /i not "%L__CLI%" == "True" (set "L__CLI=") + +:RelaunchInConEmu +set RELOAD_IN_CONEMU=True +if defined ConEmuBuild set "RELOAD_IN_CONEMU=" +if defined L_NCMD set "RELOAD_IN_CONEMU=" +if "%L_TYPE%" == "Executable" set "RELOAD_IN_CONEMU=" +if "%L_TYPE%" == "PSScript" set "RELOAD_IN_CONEMU=" +if "%L_TYPE%" == "PyScript" set "RELOAD_IN_CONEMU=" + +if defined RELOAD_IN_CONEMU ( + set "con_args=-new_console:n" + rem If in DEBUG state then force ConEmu to stay open + if defined DEBUG (set "con_args=!con_args! -new_console:c") + start "" "%CON%" -run ""%~0" %*" !con_args! || goto ErrorUnknown + exit /b 0 +) + +:CheckLaunchType +rem Jump to the selected launch type or show usage +if /i "%L_TYPE%" == "Executable" (goto LaunchExecutable) +if /i "%L_TYPE%" == "Folder" (goto LaunchFolder) +if /i "%L_TYPE%" == "Office" (goto LaunchOffice) +if /i "%L_TYPE%" == "PSScript" (goto LaunchPSScript) +if /i "%L_TYPE%" == "PyScript" (goto LaunchPyScript) +if /i "%L_TYPE%" == "QuickBooks" (goto LaunchQuickBooksSetup) +goto Usage + +:LaunchExecutable +rem Prep +call :ExtractOrFindPath || goto ErrorProgramNotFound + +rem Check for 64-bit prog (if running on 64-bit system) +set "prog=%_path%\%L_ITEM%" +if %ARCH% equ 64 ( + if exist "%_path%\%L_ITEM:.=64.%" set "prog=%_path%\%L_ITEM:.=64.%" +) +if not exist "%prog%" goto ErrorProgramNotFound + +rem Run +popd && pushd "%_path%" +if defined L__CLI goto LaunchExecutableCLI +if defined L_ELEV ( + goto LaunchExecutableElev +) else ( + goto LaunchExecutableUser +) + +:LaunchExecutableCLI +rem Prep +set "con_args=-new_console:n" +if defined DEBUG (set "con_args=%con_args% -new_console:c") +if defined L_ELEV (set "con_args=%con_args% -new_console:a") + +rem Run +start "" "%CON%" -run "%prog%" %L_ARGS% %con_args% || goto ErrorUnknown +goto Exit + +:LaunchExecutableElev +rem Prep +call :DeQuote prog +call :DeQuote L_ARGS + +rem Create VB script +mkdir "%bin%\tmp" 2>nul +echo Set UAC = CreateObject^("Shell.Application"^) > "%bin%\tmp\Elevate.vbs" +echo UAC.ShellExecute "%prog%", "%L_ARGS%", "", "runas", 1 >> "%bin%\tmp\Elevate.vbs" + +rem Run +"%systemroot%\System32\cscript.exe" //nologo "%bin%\tmp\Elevate.vbs" || goto ErrorUnknown +goto Exit + +:LaunchExecutableUser +rem Run +start "" "%prog%" %L_ARGS% || goto ErrorUnknown +goto Exit + +:LaunchFolder +rem Prep +call :ExtractOrFindPath || goto ErrorProgramNotFound + +rem Run +start "" "explorer.exe" "%_path%" || goto ErrorUnknown +goto Exit + +:LaunchOffice +call "%bin%\Scripts\init_client_dir.cmd" /Office +set "_odt=False" +if %L_PATH% equ 2013 (set "_odt=True") +if %L_PATH% equ 2016 (set "_odt=True") +if "%_odt%" == "True" ( + goto LaunchOfficeODT +) else ( + goto LaunchOfficeSetup +) + +:LaunchOfficeODT +rem Prep +set "args=-aoa -bso0 -bse0 -bsp0 -p%ARCHIVE_PASSWORD%" +set "config=%L_ITEM%" +set "dest=%client_dir%\Office\%L_PATH%" +set "odt_exe=%L_PATH%\setup.exe" +set "source=%cbin%\_Office.7z" + +rem Extract +if not exist "%source%" (goto ErrorODTSourceNotFound) +"%SEVEN_ZIP%" e "%source%" %args% -o"%dest%" %odt_exe% %config% || exit /b 1 +"%systemroot%\System32\ping.exe" -n 2 127.0.0.1>nul + +rem Verify +if not exist "%dest%\setup.exe" (goto ErrorODTSourceNotFound) +if not exist "%dest%\%config%" (goto ErrorODTSourceNotFound) +pushd "%dest%" + +rem Run +rem # The line below jumps to ErrorUnknown even when it runs correctly?? +rem start "" "setup.exe" /configure %L_ITEM% || popd & goto ErrorUnknown +rem # Going to assume it extracted correctly and blindly start setup.exe +start "" "setup.exe" /configure %config% +popd +goto Exit + +:LaunchOfficeSetup +rem Prep +set "fastcopy_args=/cmd=diff /no_ui /auto_close" +set "product=%L_PATH%\%L_ITEM%" +set "product_name=%L_ITEM%" +call :GetBasename product_name || goto ErrorBasename +set "source=\\%OFFICE_SERVER_IP%\Office\%product%" +set "dest=%client_dir%\Office" + +rem Verify +if not exist "%source%" (goto ErrorOfficeSourceNotFound) + +rem Copy +echo Copying setup file(s) for %product_name%... +start "" /wait "%FASTCOPY%" %fastcopy_args% "%source%" /to="%dest%\" + +rem Run +if exist "%dest%\%product_name%\setup.exe" ( + start "" "%dest%\%product_name%\setup.exe" || goto ErrorUnknown +) else if "%product_name:~-3,3%" == "exe" ( + start "" "%dest%\%product_name%" || goto ErrorUnknown +) else if "%product_name:~-3,3%" == "msi" ( + start "" "%dest%\%product_name%" || goto ErrorUnknown +) else ( + rem Office source not supported by this script + goto ErrorOfficeUnsupported +) +goto Exit + +:LaunchPSScript +rem Prep +call :ExtractOrFindPath || goto ErrorProgramNotFound +set "script=%_path%\%L_ITEM%" +set "ps_args=-ExecutionPolicy Bypass -NoProfile" + +rem Verify +if not exist "%script%" goto ErrorScriptNotFound + +rem Run +popd && pushd "%_path%" +if defined L_ELEV ( + goto LaunchPSScriptElev +) else ( + goto LaunchPSScriptUser +) + +:LaunchPSScriptElev +rem Prep +call :DeQuote script + +rem Create VB script +mkdir "%bin%\tmp" 2>nul +echo Set UAC = CreateObject^("Shell.Application"^) > "%bin%\tmp\Elevate.vbs" +if defined L_NCMD ( + rem use Powershell's window instead of %CON% + echo UAC.ShellExecute "%POWERSHELL%", "%ps_args% -File "%script%"", "", "runas", 3 >> "%bin%\tmp\Elevate.vbs" +) else ( + echo UAC.ShellExecute "%CON%", "-run %POWERSHELL% %ps_args% -File "%script%" -new_console:n", "", "runas", 1 >> "%bin%\tmp\Elevate.vbs" +) + +rem Run +"%systemroot%\System32\cscript.exe" //nologo "%bin%\tmp\Elevate.vbs" || goto ErrorUnknown +goto Exit + +:LaunchPSScriptUser +rem Run +if defined L_NCMD ( + start "" "%POWERSHELL%" %ps_args% -File "%script%" || goto ErrorUnknown +) else ( + start "" "%CON%" -run "%POWERSHELL%" %ps_args% -File "%script%" -new_console:n || goto ErrorUnknown +) +goto Exit + +:LaunchPyScript +rem Prep +call :ExtractOrFindPath || goto ErrorProgramNotFound +set "script=%_path%\%L_ITEM%" + +rem Verify +if not exist "%script%" goto ErrorScriptNotFound + +rem Run +if defined L_ELEV ( + goto LaunchPyScriptElev +) else ( + goto LaunchPyScriptUser +) + +:LaunchPyScriptElev +rem Prep +call :DeQuote script + +rem Create VB script +mkdir "%bin%\tmp" 2>nul +echo Set UAC = CreateObject^("Shell.Application"^) > "%bin%\tmp\Elevate.vbs" +if defined L_NCMD ( + echo UAC.ShellExecute "%PYTHON%", "%script%", "", "runas", 3 >> "%bin%\tmp\Elevate.vbs" +) else ( + echo UAC.ShellExecute "%CON%", "-run %PYTHON% %script% -new_console:n", "", "runas", 1 >> "%bin%\tmp\Elevate.vbs" +) + +rem Run +"%systemroot%\System32\cscript.exe" //nologo "%bin%\tmp\Elevate.vbs" || goto ErrorUnknown +goto Exit + +:LaunchPyScriptUser +if defined L_NCMD ( + start "" "%PYTHON%" "%script%" || goto ErrorUnknown +) else ( + start "" "%CON%" -run "%PYTHON%" "%script%" -new_console:n || goto ErrorUnknown +) +goto Exit + +:LaunchQuickBooksSetup +rem Prep +call "%bin%\Scripts\init_client_dir.cmd" /QuickBooks +set "fastcopy_args=/cmd=diff /no_ui /auto_close" +set "product=%L_PATH%\%L_ITEM%" +set "product_name=%L_ITEM%" +call :GetBasename product_name || goto ErrorBasename +set "source=\\%QUICKBOOKS_SERVER_IP%\QuickBooks\%product%" +set "dest=%client_dir%\QuickBooks" + +rem Verify +if not exist "%source%" (goto ErrorQuickBooksSourceNotFound) + +rem Copy +echo Copying setup file(s) for %L_ITEM%... +start "" /wait "%FASTCOPY%" %fastcopy_args% "%source%" /to="%dest%\" + +rem Run +if exist "%dest%\%product_name%\Setup.exe" ( + pushd "%dest%\%product_name%" + start "" "%dest%\%product_name%\Setup.exe" || goto ErrorUnknown + popd +) else ( + rem QuickBooks source not supported by this script + goto ErrorQuickBooksUnsupported +) +goto Exit + +:Usage +echo. +echo.Usage (via defined variables): +echo. L_TYPE L_PATH L_ITEM L_ARGS +echo. Executable Working Dir Program Args [L_7ZIP] [L_ELEV] [L__CLI] +echo. Folder Folder '.' [L_7ZIP] +echo. Office Year Product [L_7ZIP] +echo. PSScript Scripts Script [L_7ZIP] [L_ELEV] [L_NCMD] +echo. PyScript Scripts Script [L_7ZIP] [L_ELEV] [L_NCMD] +echo. QuickBooks Year Product [L_7ZIP] +echo. +echo.L_7ZIP: Extra arguments for 7-Zip (in the :ExtractCBin label) +echo.L_ELEV: Elevate to run as Admin +echo.L_NCMD: Do not run script inside ConEmu (i.e. use the native window) +echo.L__CLI: Run executable in ConEmu +echo. +goto Abort + +:: Functions :: +:DeQuote +rem Code taken from http://ss64.com/nt/syntax-dequote.html +if not defined %1 (@exit /b 1) +for /f "delims=" %%a in ('echo %%%1%%') do set %1=%%~a +@exit /b 0 + +:ExtractCBin +rem Extract %cbin% archive into %bin% +echo Extracting "%L_PATH%"... +set "source=%cbin%\%L_PATH%.7z" +set "dest=%bin%\%L_PATH%" +set "args=-aos -bso0 -bse0 -bsp0 -p%ARCHIVE_PASSWORD%" +if defined DEBUG (set "args=-aos -p%ARCHIVE_PASSWORD%") +"%SEVEN_ZIP%" x "%source%" %args% -o"%dest%" %L_7ZIP% || exit /b 1 +ping.exe -n 2 127.0.0.1>nul +exit /b 0 + +:FindBin +rem Checks the current directory and all parents for the ".bin" folder +rem NOTE: Has not been tested for UNC paths +set bin= +pushd "%~dp0" +:FindBinInner +if exist ".bin" (goto FindBinDone) +if "%~d0\" == "%cd%" (popd & @exit /b 1) +cd .. +goto FindBinInner +:FindBinDone +set "bin=%cd%\.bin" +set "cbin=%cd%\.cbin" +popd +@exit /b 0 + +:GetBasename +rem Loop over passed variable to remove all text left of the last '\' character +rem NOTE: This function should be called as 'call :GetBasename VarName || goto ErrorBasename' to catch variables that become empty. +for /f "delims=" %%a in ('echo %%%1%%') do (set "_tmp=%%~a") +:GetBasenameInner +set "_tmp=%_tmp:*\=%" +if not defined _tmp (@exit /b 1) +if not "%_tmp%" == "%_tmp:*\=%" (goto GetBasenameInner) +:GetBasenameDone +set "%1=%_tmp%" +@exit /b 0 + +:ExtractOrFindPath +rem Test L_PATH in the following order: +rem 1: %cbin%\L_PATH.7z (which will be extracted to %bin%\L_PATH) +rem 2: %bin%\L_PATH +rem 3. %L_PATH% (i.e. treat L_PATH as an absolute path) +rem NOTE: This function should be called as 'call :ExtractOrFindPath || goto ErrorProgramNotFound' to catch invalid paths. +set _path= +if exist "%cbin%\%L_PATH%.7z" ( + call :ExtractCBin +) else if exist "%cbin%\%L_PATH%\%L_ITEM:~0,-4%.7z" ( + call :ExtractCBin +) +if exist "%bin%\%L_PATH%" (set "_path=%bin%\%L_PATH%") +if not defined _path (set "_path=%L_PATH%") +rem Raise error if path is still not available +if not exist "%_path%" (exit /b 1) +exit /b 0 + +:: Errors :: +:ErrorBasename +echo. +echo ERROR: GetBasename resulted in an empty variable. +goto Abort + +:ErrorNoBin +echo. +echo ERROR: ".bin" folder not found. +goto Abort + +:ErrorODTSourceNotFound +echo. +echo ERROR: Office Deployment Tool source not found. +goto Abort + +:ErrorOfficeSourceNotFound +echo. +echo ERROR: Office source "%L_ITEM%" not found. +goto Abort + +:ErrorOfficeUnsupported +rem Source is not an executable nor is a folder with a setup.exe file inside. Open explorer to local setup file(s) instead. +echo. +echo ERROR: Office version not supported by this script. +start "" "explorer.exe" "%client_dir%\Office" +goto Abort + +:ErrorQuickBooksSourceNotFound +echo. +echo ERROR: QuickBooks source "%L_ITEM%" not found. +goto Abort + +:ErrorQuickBooksUnsupported +rem Source is not an executable nor is a folder with a setup.exe file inside. Open explorer to local setup file(s) instead. +echo. +echo ERROR: QuickBooks version not supported by this script. +start "" "explorer.exe" "%client_dir%\QuickBooks" +goto Abort + +:ErrorProgramNotFound +echo. +echo ERROR: Program "%prog%" not found. +goto Abort + +:ErrorScriptNotFound +echo. +echo ERROR: Script "%script%" not found. +goto Abort + +:ErrorUnknown +echo. +echo ERROR: Unknown error encountered. +goto Abort + +:Abort +rem Handle color theme for both the native console and ConEmu +if defined ConEmuBuild ( + color c4 +) else ( + color 4e +) +echo Aborted. +echo. +echo DETAILS: L_TYPE: %L_TYPE% +echo. L_PATH: %L_PATH% +echo. L_ITEM: %L_ITEM% +echo. L_ARGS: %L_ARGS% +echo. L_7ZIP: %L_7ZIP% +echo. L_ELEV: %L_ELEV% +echo. L_NCMD: %L_NCMD% +echo. L__CLI: %L__CLI% +echo. CON: %CON% +echo. DEBUG: %DEBUG% +echo. PYTHON: %PYTHON% +echo Press any key to exit... +pause>nul +rem reset color and reset errorlevel to 0 +rem NOTE: This is done to avoid causing a ErrorLaunchCMD in the launcher.cmd +color +goto Exit + +:: Cleanup and exit :: +:Exit +popd +endlocal exit /b %errorlevel% \ No newline at end of file diff --git a/.bin/Scripts/Launcher_Template.cmd b/.bin/Scripts/Launcher_Template.cmd index d5b68d9b..a4b262e0 100644 --- a/.bin/Scripts/Launcher_Template.cmd +++ b/.bin/Scripts/Launcher_Template.cmd @@ -1,113 +1,113 @@ -:: Wizard Kit: Launcher Script :: -:: -:: This script works by setting env variables and then calling Launch.cmd -:: which inherits the variables. This bypasses batch file argument parsing -:: which is awful. -@echo off - -:Init -setlocal EnableDelayedExpansion -title Wizard Kit: Launcher -call :CheckFlags %* -call :FindBin -call :SetTitle Launcher - -:Optional -:: This section is for any work that needs done before launching L_ITEM -rem EXTRA_CODE - -:DefineLaunch -:: See %bin%\SCripts\Launch.cmd for details under :Usage label -set L_TYPE= -set L_PATH= -set L_ITEM= -set L_ARGS= -set L__CLI= -set L_7ZIP= -set L_ELEV= -set L_NCMD= - -::::::::::::::::::::::::::::::::::::::::::: -:: Do not edit anything below this line! :: -::::::::::::::::::::::::::::::::::::::::::: - -:LaunchPrep -rem Verifies the environment before launching item -if not defined bin (goto ErrorNoBin) -if not exist "%bin%\Scripts\Launch.cmd" (goto ErrorLaunchCMDMissing) - -:Launch -rem Calls the Launch.cmd script using the variables defined above -call "%bin%\Scripts\Launch.cmd" || goto ErrorLaunchCMD -goto Exit - -:: Functions :: -:CheckFlags -rem Loops through all arguments to check for accepted flags -set DEBUG= -for %%f in (%*) do ( - if /i "%%f" == "/DEBUG" (@echo on & set "DEBUG=/DEBUG") -) -@exit /b 0 - -:FindBin -rem Checks the current directory and all parents for the ".bin" folder -rem NOTE: Has not been tested for UNC paths -set bin= -pushd "%~dp0" -:FindBinInner -if exist ".bin" (goto FindBinDone) -if "%~d0\" == "%cd%" (popd & @exit /b 1) -cd .. -goto FindBinInner -:FindBinDone -set "bin=%cd%\.bin" -set "cbin=%cd%\.cbin" -popd -@exit /b 0 - -:SetTitle -rem Sets title using KIT_NAME_FULL from settings\main.py -set "SETTINGS=%bin%\Scripts\settings\main.py" -for /f "tokens=* usebackq" %%f in (`findstr KIT_NAME_FULL %SETTINGS%`) do ( - set "_v=%%f" - set "_v=!_v:*'=!" - set "KIT_NAME_FULL=!_v:~0,-1!" -) -set "window_title=%*" -if not defined window_title set "window_title=Launcher" -set "window_title=%KIT_NAME_FULL%: %window_title%" -title %window_title% -@exit /b 0 - -:: Errors :: -:ErrorLaunchCMD -echo. -echo ERROR: Launch.cmd did not run correctly. Try using the /DEBUG flag? -goto Abort - -:ErrorLaunchCMDMissing -echo. -echo ERROR: Launch.cmd script not found. -goto Abort - -:ErrorNoBin -echo. -echo ERROR: ".bin" folder not found. -goto Abort - -:Abort -color 4e -echo Aborted. -echo. -echo Press any key to exit... -pause>nul -color -rem Set errorlevel to 1 by calling color incorrectly -color 00 -goto Exit - -:: Cleanup and exit :: -:Exit -endlocal +:: Wizard Kit: Launcher Script :: +:: +:: This script works by setting env variables and then calling Launch.cmd +:: which inherits the variables. This bypasses batch file argument parsing +:: which is awful. +@echo off + +:Init +setlocal EnableDelayedExpansion +title Wizard Kit: Launcher +call :CheckFlags %* +call :FindBin +call :SetTitle Launcher + +:Optional +:: This section is for any work that needs done before launching L_ITEM +rem EXTRA_CODE + +:DefineLaunch +:: See %bin%\SCripts\Launch.cmd for details under :Usage label +set L_TYPE= +set L_PATH= +set L_ITEM= +set L_ARGS= +set L__CLI= +set L_7ZIP= +set L_ELEV= +set L_NCMD= + +::::::::::::::::::::::::::::::::::::::::::: +:: Do not edit anything below this line! :: +::::::::::::::::::::::::::::::::::::::::::: + +:LaunchPrep +rem Verifies the environment before launching item +if not defined bin (goto ErrorNoBin) +if not exist "%bin%\Scripts\Launch.cmd" (goto ErrorLaunchCMDMissing) + +:Launch +rem Calls the Launch.cmd script using the variables defined above +call "%bin%\Scripts\Launch.cmd" || goto ErrorLaunchCMD +goto Exit + +:: Functions :: +:CheckFlags +rem Loops through all arguments to check for accepted flags +set DEBUG= +for %%f in (%*) do ( + if /i "%%f" == "/DEBUG" (@echo on & set "DEBUG=/DEBUG") +) +@exit /b 0 + +:FindBin +rem Checks the current directory and all parents for the ".bin" folder +rem NOTE: Has not been tested for UNC paths +set bin= +pushd "%~dp0" +:FindBinInner +if exist ".bin" (goto FindBinDone) +if "%~d0\" == "%cd%" (popd & @exit /b 1) +cd .. +goto FindBinInner +:FindBinDone +set "bin=%cd%\.bin" +set "cbin=%cd%\.cbin" +popd +@exit /b 0 + +:SetTitle +rem Sets title using KIT_NAME_FULL from settings\main.py +set "SETTINGS=%bin%\Scripts\settings\main.py" +for /f "tokens=* usebackq" %%f in (`findstr KIT_NAME_FULL %SETTINGS%`) do ( + set "_v=%%f" + set "_v=!_v:*'=!" + set "KIT_NAME_FULL=!_v:~0,-1!" +) +set "window_title=%*" +if not defined window_title set "window_title=Launcher" +set "window_title=%KIT_NAME_FULL%: %window_title%" +title %window_title% +@exit /b 0 + +:: Errors :: +:ErrorLaunchCMD +echo. +echo ERROR: Launch.cmd did not run correctly. Try using the /DEBUG flag? +goto Abort + +:ErrorLaunchCMDMissing +echo. +echo ERROR: Launch.cmd script not found. +goto Abort + +:ErrorNoBin +echo. +echo ERROR: ".bin" folder not found. +goto Abort + +:Abort +color 4e +echo Aborted. +echo. +echo Press any key to exit... +pause>nul +color +rem Set errorlevel to 1 by calling color incorrectly +color 00 +goto Exit + +:: Cleanup and exit :: +:Exit +endlocal exit /b %errorlevel% \ No newline at end of file diff --git a/.bin/Scripts/activate.py b/.bin/Scripts/activate.py index 9135ca34..5bb7eba2 100644 --- a/.bin/Scripts/activate.py +++ b/.bin/Scripts/activate.py @@ -1,60 +1,60 @@ -# Wizard Kit: Activate Windows using various methods - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.activation import * -init_global_vars() -os.system('title {}: Windows Activation Tool'.format(KIT_NAME_FULL)) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: Windows Activation Tool\n'.format(KIT_NAME_FULL)) - # Bail early if already activated - if windows_is_activated(): - print_info('This system is already activated') - sleep(5) - exit_script() - other_results = { - 'Error': { - 'BIOSKeyNotFoundError': 'BIOS key not found.', - }} - - # Determine activation method - activation_methods = [ - {'Name': 'Activate with BIOS key', 'Function': activate_with_bios}, - ] - if global_vars['OS']['Version'] not in ['8', '10']: - activation_methods[0]['Disabled'] = True - actions = [ - {'Name': 'Quit', 'Letter': 'Q'}, - ] - - while True: - selection = menu_select( - '{}: Windows Activation Menu'.format(KIT_NAME_FULL), - main_entries=activation_methods, action_entries=actions) - - if (selection.isnumeric()): - result = try_and_print( - message = activation_methods[int(selection)-1]['Name'], - function = activation_methods[int(selection)-1]['Function'], - other_results=other_results) - if result['CS']: - break - elif selection == 'Q': - exit_script() - - # Done - print_success('\nDone.') - pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Activate Windows using various methods + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.activation import * +init_global_vars() +os.system('title {}: Windows Activation Tool'.format(KIT_NAME_FULL)) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: Windows Activation Tool\n'.format(KIT_NAME_FULL)) + # Bail early if already activated + if windows_is_activated(): + print_info('This system is already activated') + sleep(5) + exit_script() + other_results = { + 'Error': { + 'BIOSKeyNotFoundError': 'BIOS key not found.', + }} + + # Determine activation method + activation_methods = [ + {'Name': 'Activate with BIOS key', 'Function': activate_with_bios}, + ] + if global_vars['OS']['Version'] not in ['8', '10']: + activation_methods[0]['Disabled'] = True + actions = [ + {'Name': 'Quit', 'Letter': 'Q'}, + ] + + while True: + selection = menu_select( + '{}: Windows Activation Menu'.format(KIT_NAME_FULL), + main_entries=activation_methods, action_entries=actions) + + if (selection.isnumeric()): + result = try_and_print( + message = activation_methods[int(selection)-1]['Name'], + function = activation_methods[int(selection)-1]['Function'], + other_results=other_results) + if result['CS']: + break + elif selection == 'Q': + exit_script() + + # Done + print_success('\nDone.') + pause("Press Enter to exit...") + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/borrowed/acpi.py b/.bin/Scripts/borrowed/acpi.py index bb109caf..5b8e4dac 100644 --- a/.bin/Scripts/borrowed/acpi.py +++ b/.bin/Scripts/borrowed/acpi.py @@ -1,57 +1,57 @@ -import sys - -# Code borrowed from https://github.com/aeruder/get_win8key - -if sys.platform.startswith('win32'): - import ctypes - import ctypes.wintypes - - def EnumAcpiTables(): - #returns a list of the names of the ACPI tables on this system - FirmwareTableProviderSignature=ctypes.wintypes.DWORD(1094930505) - pFirmwareTableBuffer=ctypes.create_string_buffer(0) - BufferSize=ctypes.wintypes.DWORD(0) - #http://msdn.microsoft.com/en-us/library/windows/desktop/ms724259 - EnumSystemFirmwareTables=ctypes.WinDLL("Kernel32").EnumSystemFirmwareTables - ret=EnumSystemFirmwareTables(FirmwareTableProviderSignature, pFirmwareTableBuffer, BufferSize) - pFirmwareTableBuffer=None - pFirmwareTableBuffer=ctypes.create_string_buffer(ret) - BufferSize.value=ret - ret2=EnumSystemFirmwareTables(FirmwareTableProviderSignature, pFirmwareTableBuffer, BufferSize) - return [pFirmwareTableBuffer.value[i:i+4] for i in range(0, len(pFirmwareTableBuffer.value), 4)] - - def GetAcpiTable(table): - #returns raw contents of ACPI table - #http://msdn.microsoft.com/en-us/library/windows/desktop/ms724379x - tableID = 0 - for b in reversed(table): - tableID = (tableID << 8) + b - GetSystemFirmwareTable=ctypes.WinDLL("Kernel32").GetSystemFirmwareTable - FirmwareTableProviderSignature=ctypes.wintypes.DWORD(1094930505) - FirmwareTableID=ctypes.wintypes.DWORD(int(tableID)) - pFirmwareTableBuffer=ctypes.create_string_buffer(0) - BufferSize=ctypes.wintypes.DWORD(0) - ret = GetSystemFirmwareTable(FirmwareTableProviderSignature, FirmwareTableID, pFirmwareTableBuffer, BufferSize) - pFirmwareTableBuffer=None - pFirmwareTableBuffer=ctypes.create_string_buffer(ret) - BufferSize.value=ret - ret2 = GetSystemFirmwareTable(FirmwareTableProviderSignature, FirmwareTableID, pFirmwareTableBuffer, BufferSize) - return pFirmwareTableBuffer.raw -elif sys.platform.startswith('linux'): - import os - TABLE_ROOT = b'/sys/firmware/acpi/tables' - def EnumAcpiTables(): - return os.listdir(TABLE_ROOT) - def GetAcpiTable(table): - with open(os.path.join(TABLE_ROOT, table), 'rb') as o: - return o.read() -else: - raise NotImplementedError('acpi support only implemented for linux and win32') - -def FindAcpiTable(table): -#checks if specific ACPI table exists and returns True/False - tables = EnumAcpiTables() - if table in tables: - return True - else: - return False +import sys + +# Code borrowed from https://github.com/aeruder/get_win8key + +if sys.platform.startswith('win32'): + import ctypes + import ctypes.wintypes + + def EnumAcpiTables(): + #returns a list of the names of the ACPI tables on this system + FirmwareTableProviderSignature=ctypes.wintypes.DWORD(1094930505) + pFirmwareTableBuffer=ctypes.create_string_buffer(0) + BufferSize=ctypes.wintypes.DWORD(0) + #http://msdn.microsoft.com/en-us/library/windows/desktop/ms724259 + EnumSystemFirmwareTables=ctypes.WinDLL("Kernel32").EnumSystemFirmwareTables + ret=EnumSystemFirmwareTables(FirmwareTableProviderSignature, pFirmwareTableBuffer, BufferSize) + pFirmwareTableBuffer=None + pFirmwareTableBuffer=ctypes.create_string_buffer(ret) + BufferSize.value=ret + ret2=EnumSystemFirmwareTables(FirmwareTableProviderSignature, pFirmwareTableBuffer, BufferSize) + return [pFirmwareTableBuffer.value[i:i+4] for i in range(0, len(pFirmwareTableBuffer.value), 4)] + + def GetAcpiTable(table): + #returns raw contents of ACPI table + #http://msdn.microsoft.com/en-us/library/windows/desktop/ms724379x + tableID = 0 + for b in reversed(table): + tableID = (tableID << 8) + b + GetSystemFirmwareTable=ctypes.WinDLL("Kernel32").GetSystemFirmwareTable + FirmwareTableProviderSignature=ctypes.wintypes.DWORD(1094930505) + FirmwareTableID=ctypes.wintypes.DWORD(int(tableID)) + pFirmwareTableBuffer=ctypes.create_string_buffer(0) + BufferSize=ctypes.wintypes.DWORD(0) + ret = GetSystemFirmwareTable(FirmwareTableProviderSignature, FirmwareTableID, pFirmwareTableBuffer, BufferSize) + pFirmwareTableBuffer=None + pFirmwareTableBuffer=ctypes.create_string_buffer(ret) + BufferSize.value=ret + ret2 = GetSystemFirmwareTable(FirmwareTableProviderSignature, FirmwareTableID, pFirmwareTableBuffer, BufferSize) + return pFirmwareTableBuffer.raw +elif sys.platform.startswith('linux'): + import os + TABLE_ROOT = b'/sys/firmware/acpi/tables' + def EnumAcpiTables(): + return os.listdir(TABLE_ROOT) + def GetAcpiTable(table): + with open(os.path.join(TABLE_ROOT, table), 'rb') as o: + return o.read() +else: + raise NotImplementedError('acpi support only implemented for linux and win32') + +def FindAcpiTable(table): +#checks if specific ACPI table exists and returns True/False + tables = EnumAcpiTables() + if table in tables: + return True + else: + return False diff --git a/.bin/Scripts/borrowed/knownpaths-LICENSE.txt b/.bin/Scripts/borrowed/knownpaths-LICENSE.txt index 19673bd6..d4b2f60c 100644 --- a/.bin/Scripts/borrowed/knownpaths-LICENSE.txt +++ b/.bin/Scripts/borrowed/knownpaths-LICENSE.txt @@ -1,21 +1,21 @@ -The MIT License (MIT) - -Copyright (c) 2014 Michael Kropat - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. +The MIT License (MIT) + +Copyright (c) 2014 Michael Kropat + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/.bin/Scripts/borrowed/knownpaths.py b/.bin/Scripts/borrowed/knownpaths.py index 96b1a009..53be87f9 100644 --- a/.bin/Scripts/borrowed/knownpaths.py +++ b/.bin/Scripts/borrowed/knownpaths.py @@ -1,164 +1,164 @@ -import ctypes, sys -from ctypes import windll, wintypes -from uuid import UUID - -class GUID(ctypes.Structure): # [1] - _fields_ = [ - ("Data1", wintypes.DWORD), - ("Data2", wintypes.WORD), - ("Data3", wintypes.WORD), - ("Data4", wintypes.BYTE * 8) - ] - - def __init__(self, uuid_): - ctypes.Structure.__init__(self) - self.Data1, self.Data2, self.Data3, self.Data4[0], self.Data4[1], rest = uuid_.fields - for i in range(2, 8): - self.Data4[i] = rest>>(8 - i - 1)*8 & 0xff - -class FOLDERID: # [2] - AccountPictures = UUID('{008ca0b1-55b4-4c56-b8a8-4de4b299d3be}') - AdminTools = UUID('{724EF170-A42D-4FEF-9F26-B60E846FBA4F}') - ApplicationShortcuts = UUID('{A3918781-E5F2-4890-B3D9-A7E54332328C}') - CameraRoll = UUID('{AB5FB87B-7CE2-4F83-915D-550846C9537B}') - CDBurning = UUID('{9E52AB10-F80D-49DF-ACB8-4330F5687855}') - CommonAdminTools = UUID('{D0384E7D-BAC3-4797-8F14-CBA229B392B5}') - CommonOEMLinks = UUID('{C1BAE2D0-10DF-4334-BEDD-7AA20B227A9D}') - CommonPrograms = UUID('{0139D44E-6AFE-49F2-8690-3DAFCAE6FFB8}') - CommonStartMenu = UUID('{A4115719-D62E-491D-AA7C-E74B8BE3B067}') - CommonStartup = UUID('{82A5EA35-D9CD-47C5-9629-E15D2F714E6E}') - CommonTemplates = UUID('{B94237E7-57AC-4347-9151-B08C6C32D1F7}') - Contacts = UUID('{56784854-C6CB-462b-8169-88E350ACB882}') - Cookies = UUID('{2B0F765D-C0E9-4171-908E-08A611B84FF6}') - Desktop = UUID('{B4BFCC3A-DB2C-424C-B029-7FE99A87C641}') - DeviceMetadataStore = UUID('{5CE4A5E9-E4EB-479D-B89F-130C02886155}') - Documents = UUID('{FDD39AD0-238F-46AF-ADB4-6C85480369C7}') - DocumentsLibrary = UUID('{7B0DB17D-9CD2-4A93-9733-46CC89022E7C}') - Downloads = UUID('{374DE290-123F-4565-9164-39C4925E467B}') - Favorites = UUID('{1777F761-68AD-4D8A-87BD-30B759FA33DD}') - Fonts = UUID('{FD228CB7-AE11-4AE3-864C-16F3910AB8FE}') - GameTasks = UUID('{054FAE61-4DD8-4787-80B6-090220C4B700}') - History = UUID('{D9DC8A3B-B784-432E-A781-5A1130A75963}') - ImplicitAppShortcuts = UUID('{BCB5256F-79F6-4CEE-B725-DC34E402FD46}') - InternetCache = UUID('{352481E8-33BE-4251-BA85-6007CAEDCF9D}') - Libraries = UUID('{1B3EA5DC-B587-4786-B4EF-BD1DC332AEAE}') - Links = UUID('{bfb9d5e0-c6a9-404c-b2b2-ae6db6af4968}') - LocalAppData = UUID('{F1B32785-6FBA-4FCF-9D55-7B8E7F157091}') - LocalAppDataLow = UUID('{A520A1A4-1780-4FF6-BD18-167343C5AF16}') - LocalizedResourcesDir = UUID('{2A00375E-224C-49DE-B8D1-440DF7EF3DDC}') - Music = UUID('{4BD8D571-6D19-48D3-BE97-422220080E43}') - MusicLibrary = UUID('{2112AB0A-C86A-4FFE-A368-0DE96E47012E}') - NetHood = UUID('{C5ABBF53-E17F-4121-8900-86626FC2C973}') - OriginalImages = UUID('{2C36C0AA-5812-4b87-BFD0-4CD0DFB19B39}') - PhotoAlbums = UUID('{69D2CF90-FC33-4FB7-9A0C-EBB0F0FCB43C}') - PicturesLibrary = UUID('{A990AE9F-A03B-4E80-94BC-9912D7504104}') - Pictures = UUID('{33E28130-4E1E-4676-835A-98395C3BC3BB}') - Playlists = UUID('{DE92C1C7-837F-4F69-A3BB-86E631204A23}') - PrintHood = UUID('{9274BD8D-CFD1-41C3-B35E-B13F55A758F4}') - Profile = UUID('{5E6C858F-0E22-4760-9AFE-EA3317B67173}') - ProgramData = UUID('{62AB5D82-FDC1-4DC3-A9DD-070D1D495D97}') - ProgramFiles = UUID('{905e63b6-c1bf-494e-b29c-65b732d3d21a}') - ProgramFilesX64 = UUID('{6D809377-6AF0-444b-8957-A3773F02200E}') - ProgramFilesX86 = UUID('{7C5A40EF-A0FB-4BFC-874A-C0F2E0B9FA8E}') - ProgramFilesCommon = UUID('{F7F1ED05-9F6D-47A2-AAAE-29D317C6F066}') - ProgramFilesCommonX64 = UUID('{6365D5A7-0F0D-45E5-87F6-0DA56B6A4F7D}') - ProgramFilesCommonX86 = UUID('{DE974D24-D9C6-4D3E-BF91-F4455120B917}') - Programs = UUID('{A77F5D77-2E2B-44C3-A6A2-ABA601054A51}') - Public = UUID('{DFDF76A2-C82A-4D63-906A-5644AC457385}') - PublicDesktop = UUID('{C4AA340D-F20F-4863-AFEF-F87EF2E6BA25}') - PublicDocuments = UUID('{ED4824AF-DCE4-45A8-81E2-FC7965083634}') - PublicDownloads = UUID('{3D644C9B-1FB8-4f30-9B45-F670235F79C0}') - PublicGameTasks = UUID('{DEBF2536-E1A8-4c59-B6A2-414586476AEA}') - PublicLibraries = UUID('{48DAF80B-E6CF-4F4E-B800-0E69D84EE384}') - PublicMusic = UUID('{3214FAB5-9757-4298-BB61-92A9DEAA44FF}') - PublicPictures = UUID('{B6EBFB86-6907-413C-9AF7-4FC2ABF07CC5}') - PublicRingtones = UUID('{E555AB60-153B-4D17-9F04-A5FE99FC15EC}') - PublicUserTiles = UUID('{0482af6c-08f1-4c34-8c90-e17ec98b1e17}') - PublicVideos = UUID('{2400183A-6185-49FB-A2D8-4A392A602BA3}') - QuickLaunch = UUID('{52a4f021-7b75-48a9-9f6b-4b87a210bc8f}') - Recent = UUID('{AE50C081-EBD2-438A-8655-8A092E34987A}') - RecordedTVLibrary = UUID('{1A6FDBA2-F42D-4358-A798-B74D745926C5}') - ResourceDir = UUID('{8AD10C31-2ADB-4296-A8F7-E4701232C972}') - Ringtones = UUID('{C870044B-F49E-4126-A9C3-B52A1FF411E8}') - RoamingAppData = UUID('{3EB685DB-65F9-4CF6-A03A-E3EF65729F3D}') - RoamedTileImages = UUID('{AAA8D5A5-F1D6-4259-BAA8-78E7EF60835E}') - RoamingTiles = UUID('{00BCFC5A-ED94-4e48-96A1-3F6217F21990}') - SampleMusic = UUID('{B250C668-F57D-4EE1-A63C-290EE7D1AA1F}') - SamplePictures = UUID('{C4900540-2379-4C75-844B-64E6FAF8716B}') - SamplePlaylists = UUID('{15CA69B3-30EE-49C1-ACE1-6B5EC372AFB5}') - SampleVideos = UUID('{859EAD94-2E85-48AD-A71A-0969CB56A6CD}') - SavedGames = UUID('{4C5C32FF-BB9D-43b0-B5B4-2D72E54EAAA4}') - SavedSearches = UUID('{7d1d3a04-debb-4115-95cf-2f29da2920da}') - Screenshots = UUID('{b7bede81-df94-4682-a7d8-57a52620b86f}') - SearchHistory = UUID('{0D4C3DB6-03A3-462F-A0E6-08924C41B5D4}') - SearchTemplates = UUID('{7E636BFE-DFA9-4D5E-B456-D7B39851D8A9}') - SendTo = UUID('{8983036C-27C0-404B-8F08-102D10DCFD74}') - SidebarDefaultParts = UUID('{7B396E54-9EC5-4300-BE0A-2482EBAE1A26}') - SidebarParts = UUID('{A75D362E-50FC-4fb7-AC2C-A8BEAA314493}') - SkyDrive = UUID('{A52BBA46-E9E1-435f-B3D9-28DAA648C0F6}') - SkyDriveCameraRoll = UUID('{767E6811-49CB-4273-87C2-20F355E1085B}') - SkyDriveDocuments = UUID('{24D89E24-2F19-4534-9DDE-6A6671FBB8FE}') - SkyDrivePictures = UUID('{339719B5-8C47-4894-94C2-D8F77ADD44A6}') - StartMenu = UUID('{625B53C3-AB48-4EC1-BA1F-A1EF4146FC19}') - Startup = UUID('{B97D20BB-F46A-4C97-BA10-5E3608430854}') - System = UUID('{1AC14E77-02E7-4E5D-B744-2EB1AE5198B7}') - SystemX86 = UUID('{D65231B0-B2F1-4857-A4CE-A8E7C6EA7D27}') - Templates = UUID('{A63293E8-664E-48DB-A079-DF759E0509F7}') - UserPinned = UUID('{9E3995AB-1F9C-4F13-B827-48B24B6C7174}') - UserProfiles = UUID('{0762D272-C50A-4BB0-A382-697DCD729B80}') - UserProgramFiles = UUID('{5CD7AEE2-2219-4A67-B85D-6C9CE15660CB}') - UserProgramFilesCommon = UUID('{BCBD3057-CA5C-4622-B42D-BC56DB0AE516}') - Videos = UUID('{18989B1D-99B5-455B-841C-AB7C74E4DDFC}') - VideosLibrary = UUID('{491E922F-5643-4AF4-A7EB-4E7A138D8174}') - Windows = UUID('{F38BF404-1D43-42F2-9305-67DE0B28FC23}') - -class UserHandle: # [3] - current = wintypes.HANDLE(0) - common = wintypes.HANDLE(-1) - -_CoTaskMemFree = windll.ole32.CoTaskMemFree # [4] -_CoTaskMemFree.restype= None -_CoTaskMemFree.argtypes = [ctypes.c_void_p] - -_SHGetKnownFolderPath = windll.shell32.SHGetKnownFolderPath # [5] [3] -_SHGetKnownFolderPath.argtypes = [ - ctypes.POINTER(GUID), wintypes.DWORD, wintypes.HANDLE, ctypes.POINTER(ctypes.c_wchar_p) -] - -class PathNotFoundException(Exception): pass - -def get_path(folderid, user_handle=UserHandle.common): - fid = GUID(folderid) - pPath = ctypes.c_wchar_p() - S_OK = 0 - if _SHGetKnownFolderPath(ctypes.byref(fid), 0, user_handle, ctypes.byref(pPath)) != S_OK: - raise PathNotFoundException() - path = pPath.value - _CoTaskMemFree(pPath) - return path - -if __name__ == '__main__': - if len(sys.argv) < 2 or sys.argv[1] in ['-?', '/?']: - print('python knownpaths.py FOLDERID {current|common}') - sys.exit(0) - - try: - folderid = getattr(FOLDERID, sys.argv[1]) - except AttributeError: - print('Unknown folder id "%s"' % sys.argv[1], file=sys.stderr) - sys.exit(1) - - try: - if len(sys.argv) == 2: - print(get_path(folderid)) - else: - print(get_path(folderid, getattr(UserHandle, sys.argv[2]))) - except PathNotFoundException: - print('Folder not found "%s"' % ' '.join(sys.argv[1:]), file=sys.stderr) - sys.exit(1) - -# [1] http://msdn.microsoft.com/en-us/library/windows/desktop/aa373931.aspx -# [2] http://msdn.microsoft.com/en-us/library/windows/desktop/dd378457.aspx -# [3] http://msdn.microsoft.com/en-us/library/windows/desktop/bb762188.aspx -# [4] http://msdn.microsoft.com/en-us/library/windows/desktop/ms680722.aspx -# [5] http://www.themacaque.com/?p=954 +import ctypes, sys +from ctypes import windll, wintypes +from uuid import UUID + +class GUID(ctypes.Structure): # [1] + _fields_ = [ + ("Data1", wintypes.DWORD), + ("Data2", wintypes.WORD), + ("Data3", wintypes.WORD), + ("Data4", wintypes.BYTE * 8) + ] + + def __init__(self, uuid_): + ctypes.Structure.__init__(self) + self.Data1, self.Data2, self.Data3, self.Data4[0], self.Data4[1], rest = uuid_.fields + for i in range(2, 8): + self.Data4[i] = rest>>(8 - i - 1)*8 & 0xff + +class FOLDERID: # [2] + AccountPictures = UUID('{008ca0b1-55b4-4c56-b8a8-4de4b299d3be}') + AdminTools = UUID('{724EF170-A42D-4FEF-9F26-B60E846FBA4F}') + ApplicationShortcuts = UUID('{A3918781-E5F2-4890-B3D9-A7E54332328C}') + CameraRoll = UUID('{AB5FB87B-7CE2-4F83-915D-550846C9537B}') + CDBurning = UUID('{9E52AB10-F80D-49DF-ACB8-4330F5687855}') + CommonAdminTools = UUID('{D0384E7D-BAC3-4797-8F14-CBA229B392B5}') + CommonOEMLinks = UUID('{C1BAE2D0-10DF-4334-BEDD-7AA20B227A9D}') + CommonPrograms = UUID('{0139D44E-6AFE-49F2-8690-3DAFCAE6FFB8}') + CommonStartMenu = UUID('{A4115719-D62E-491D-AA7C-E74B8BE3B067}') + CommonStartup = UUID('{82A5EA35-D9CD-47C5-9629-E15D2F714E6E}') + CommonTemplates = UUID('{B94237E7-57AC-4347-9151-B08C6C32D1F7}') + Contacts = UUID('{56784854-C6CB-462b-8169-88E350ACB882}') + Cookies = UUID('{2B0F765D-C0E9-4171-908E-08A611B84FF6}') + Desktop = UUID('{B4BFCC3A-DB2C-424C-B029-7FE99A87C641}') + DeviceMetadataStore = UUID('{5CE4A5E9-E4EB-479D-B89F-130C02886155}') + Documents = UUID('{FDD39AD0-238F-46AF-ADB4-6C85480369C7}') + DocumentsLibrary = UUID('{7B0DB17D-9CD2-4A93-9733-46CC89022E7C}') + Downloads = UUID('{374DE290-123F-4565-9164-39C4925E467B}') + Favorites = UUID('{1777F761-68AD-4D8A-87BD-30B759FA33DD}') + Fonts = UUID('{FD228CB7-AE11-4AE3-864C-16F3910AB8FE}') + GameTasks = UUID('{054FAE61-4DD8-4787-80B6-090220C4B700}') + History = UUID('{D9DC8A3B-B784-432E-A781-5A1130A75963}') + ImplicitAppShortcuts = UUID('{BCB5256F-79F6-4CEE-B725-DC34E402FD46}') + InternetCache = UUID('{352481E8-33BE-4251-BA85-6007CAEDCF9D}') + Libraries = UUID('{1B3EA5DC-B587-4786-B4EF-BD1DC332AEAE}') + Links = UUID('{bfb9d5e0-c6a9-404c-b2b2-ae6db6af4968}') + LocalAppData = UUID('{F1B32785-6FBA-4FCF-9D55-7B8E7F157091}') + LocalAppDataLow = UUID('{A520A1A4-1780-4FF6-BD18-167343C5AF16}') + LocalizedResourcesDir = UUID('{2A00375E-224C-49DE-B8D1-440DF7EF3DDC}') + Music = UUID('{4BD8D571-6D19-48D3-BE97-422220080E43}') + MusicLibrary = UUID('{2112AB0A-C86A-4FFE-A368-0DE96E47012E}') + NetHood = UUID('{C5ABBF53-E17F-4121-8900-86626FC2C973}') + OriginalImages = UUID('{2C36C0AA-5812-4b87-BFD0-4CD0DFB19B39}') + PhotoAlbums = UUID('{69D2CF90-FC33-4FB7-9A0C-EBB0F0FCB43C}') + PicturesLibrary = UUID('{A990AE9F-A03B-4E80-94BC-9912D7504104}') + Pictures = UUID('{33E28130-4E1E-4676-835A-98395C3BC3BB}') + Playlists = UUID('{DE92C1C7-837F-4F69-A3BB-86E631204A23}') + PrintHood = UUID('{9274BD8D-CFD1-41C3-B35E-B13F55A758F4}') + Profile = UUID('{5E6C858F-0E22-4760-9AFE-EA3317B67173}') + ProgramData = UUID('{62AB5D82-FDC1-4DC3-A9DD-070D1D495D97}') + ProgramFiles = UUID('{905e63b6-c1bf-494e-b29c-65b732d3d21a}') + ProgramFilesX64 = UUID('{6D809377-6AF0-444b-8957-A3773F02200E}') + ProgramFilesX86 = UUID('{7C5A40EF-A0FB-4BFC-874A-C0F2E0B9FA8E}') + ProgramFilesCommon = UUID('{F7F1ED05-9F6D-47A2-AAAE-29D317C6F066}') + ProgramFilesCommonX64 = UUID('{6365D5A7-0F0D-45E5-87F6-0DA56B6A4F7D}') + ProgramFilesCommonX86 = UUID('{DE974D24-D9C6-4D3E-BF91-F4455120B917}') + Programs = UUID('{A77F5D77-2E2B-44C3-A6A2-ABA601054A51}') + Public = UUID('{DFDF76A2-C82A-4D63-906A-5644AC457385}') + PublicDesktop = UUID('{C4AA340D-F20F-4863-AFEF-F87EF2E6BA25}') + PublicDocuments = UUID('{ED4824AF-DCE4-45A8-81E2-FC7965083634}') + PublicDownloads = UUID('{3D644C9B-1FB8-4f30-9B45-F670235F79C0}') + PublicGameTasks = UUID('{DEBF2536-E1A8-4c59-B6A2-414586476AEA}') + PublicLibraries = UUID('{48DAF80B-E6CF-4F4E-B800-0E69D84EE384}') + PublicMusic = UUID('{3214FAB5-9757-4298-BB61-92A9DEAA44FF}') + PublicPictures = UUID('{B6EBFB86-6907-413C-9AF7-4FC2ABF07CC5}') + PublicRingtones = UUID('{E555AB60-153B-4D17-9F04-A5FE99FC15EC}') + PublicUserTiles = UUID('{0482af6c-08f1-4c34-8c90-e17ec98b1e17}') + PublicVideos = UUID('{2400183A-6185-49FB-A2D8-4A392A602BA3}') + QuickLaunch = UUID('{52a4f021-7b75-48a9-9f6b-4b87a210bc8f}') + Recent = UUID('{AE50C081-EBD2-438A-8655-8A092E34987A}') + RecordedTVLibrary = UUID('{1A6FDBA2-F42D-4358-A798-B74D745926C5}') + ResourceDir = UUID('{8AD10C31-2ADB-4296-A8F7-E4701232C972}') + Ringtones = UUID('{C870044B-F49E-4126-A9C3-B52A1FF411E8}') + RoamingAppData = UUID('{3EB685DB-65F9-4CF6-A03A-E3EF65729F3D}') + RoamedTileImages = UUID('{AAA8D5A5-F1D6-4259-BAA8-78E7EF60835E}') + RoamingTiles = UUID('{00BCFC5A-ED94-4e48-96A1-3F6217F21990}') + SampleMusic = UUID('{B250C668-F57D-4EE1-A63C-290EE7D1AA1F}') + SamplePictures = UUID('{C4900540-2379-4C75-844B-64E6FAF8716B}') + SamplePlaylists = UUID('{15CA69B3-30EE-49C1-ACE1-6B5EC372AFB5}') + SampleVideos = UUID('{859EAD94-2E85-48AD-A71A-0969CB56A6CD}') + SavedGames = UUID('{4C5C32FF-BB9D-43b0-B5B4-2D72E54EAAA4}') + SavedSearches = UUID('{7d1d3a04-debb-4115-95cf-2f29da2920da}') + Screenshots = UUID('{b7bede81-df94-4682-a7d8-57a52620b86f}') + SearchHistory = UUID('{0D4C3DB6-03A3-462F-A0E6-08924C41B5D4}') + SearchTemplates = UUID('{7E636BFE-DFA9-4D5E-B456-D7B39851D8A9}') + SendTo = UUID('{8983036C-27C0-404B-8F08-102D10DCFD74}') + SidebarDefaultParts = UUID('{7B396E54-9EC5-4300-BE0A-2482EBAE1A26}') + SidebarParts = UUID('{A75D362E-50FC-4fb7-AC2C-A8BEAA314493}') + SkyDrive = UUID('{A52BBA46-E9E1-435f-B3D9-28DAA648C0F6}') + SkyDriveCameraRoll = UUID('{767E6811-49CB-4273-87C2-20F355E1085B}') + SkyDriveDocuments = UUID('{24D89E24-2F19-4534-9DDE-6A6671FBB8FE}') + SkyDrivePictures = UUID('{339719B5-8C47-4894-94C2-D8F77ADD44A6}') + StartMenu = UUID('{625B53C3-AB48-4EC1-BA1F-A1EF4146FC19}') + Startup = UUID('{B97D20BB-F46A-4C97-BA10-5E3608430854}') + System = UUID('{1AC14E77-02E7-4E5D-B744-2EB1AE5198B7}') + SystemX86 = UUID('{D65231B0-B2F1-4857-A4CE-A8E7C6EA7D27}') + Templates = UUID('{A63293E8-664E-48DB-A079-DF759E0509F7}') + UserPinned = UUID('{9E3995AB-1F9C-4F13-B827-48B24B6C7174}') + UserProfiles = UUID('{0762D272-C50A-4BB0-A382-697DCD729B80}') + UserProgramFiles = UUID('{5CD7AEE2-2219-4A67-B85D-6C9CE15660CB}') + UserProgramFilesCommon = UUID('{BCBD3057-CA5C-4622-B42D-BC56DB0AE516}') + Videos = UUID('{18989B1D-99B5-455B-841C-AB7C74E4DDFC}') + VideosLibrary = UUID('{491E922F-5643-4AF4-A7EB-4E7A138D8174}') + Windows = UUID('{F38BF404-1D43-42F2-9305-67DE0B28FC23}') + +class UserHandle: # [3] + current = wintypes.HANDLE(0) + common = wintypes.HANDLE(-1) + +_CoTaskMemFree = windll.ole32.CoTaskMemFree # [4] +_CoTaskMemFree.restype= None +_CoTaskMemFree.argtypes = [ctypes.c_void_p] + +_SHGetKnownFolderPath = windll.shell32.SHGetKnownFolderPath # [5] [3] +_SHGetKnownFolderPath.argtypes = [ + ctypes.POINTER(GUID), wintypes.DWORD, wintypes.HANDLE, ctypes.POINTER(ctypes.c_wchar_p) +] + +class PathNotFoundException(Exception): pass + +def get_path(folderid, user_handle=UserHandle.common): + fid = GUID(folderid) + pPath = ctypes.c_wchar_p() + S_OK = 0 + if _SHGetKnownFolderPath(ctypes.byref(fid), 0, user_handle, ctypes.byref(pPath)) != S_OK: + raise PathNotFoundException() + path = pPath.value + _CoTaskMemFree(pPath) + return path + +if __name__ == '__main__': + if len(sys.argv) < 2 or sys.argv[1] in ['-?', '/?']: + print('python knownpaths.py FOLDERID {current|common}') + sys.exit(0) + + try: + folderid = getattr(FOLDERID, sys.argv[1]) + except AttributeError: + print('Unknown folder id "%s"' % sys.argv[1], file=sys.stderr) + sys.exit(1) + + try: + if len(sys.argv) == 2: + print(get_path(folderid)) + else: + print(get_path(folderid, getattr(UserHandle, sys.argv[2]))) + except PathNotFoundException: + print('Folder not found "%s"' % ' '.join(sys.argv[1:]), file=sys.stderr) + sys.exit(1) + +# [1] http://msdn.microsoft.com/en-us/library/windows/desktop/aa373931.aspx +# [2] http://msdn.microsoft.com/en-us/library/windows/desktop/dd378457.aspx +# [3] http://msdn.microsoft.com/en-us/library/windows/desktop/bb762188.aspx +# [4] http://msdn.microsoft.com/en-us/library/windows/desktop/ms680722.aspx +# [5] http://www.themacaque.com/?p=954 diff --git a/.bin/Scripts/build_kit.ps1 b/.bin/Scripts/build_kit.ps1 index 15d64433..bb25c8a6 100644 --- a/.bin/Scripts/build_kit.ps1 +++ b/.bin/Scripts/build_kit.ps1 @@ -1,170 +1,170 @@ -# Wizard Kit: Download kit components - -## Init ## -clear -$host.UI.RawUI.WindowTitle = "Wizard Kit: Build Tool" -$wd = $(Split-Path $MyInvocation.MyCommand.Path) -$bin = (Get-Item $wd).Parent.FullName -$root = (Get-Item "$bin\..").FullName # Get-Item $bin fails - # (I'm assuming that starting with a '.' is the issue) -$tmp = "{0}\tmp" -f $bin -$errors = 0 -pushd "$wd" -$host.UI.RawUI.BackgroundColor = "black" -$host.UI.RawUI.ForegroundColor = "white" -$progressPreference = 'silentlyContinue' - -## Functions ## -function download-file { - param ([String]$path, [String]$name, [String]$url) - $outfile = "{0}\{1}" -f $path, $name - - Write-Host ("Downloading: {0}" -f $name) - New-Item -Type Directory $path 2>&1 | Out-Null - try { - invoke-webrequest -uri $url -outfile $outfile - } - catch { - Write-Host (" ERROR: Failed to download file." ) -foregroundcolor "Red" - $errors += 1 - } -} -function find-dynamic-url { - param ([String]$source_page, [String]$regex) - $d_url = "" - - # Get source page - invoke-webrequest -uri $source_page -outfile "tmp_page" - - # Search for real url - $d_url = Get-Content "tmp_page" | Where-Object {$_ -imatch $regex} - $d_url = $d_url -ireplace '.*(a |)href="([^"]+)".*', '$2' - $d_url = $d_url -ireplace ".*(a |)href='([^']+)'.*", '$2' - - # Remove tmp_page - Remove-Item "tmp_page" - - return $d_url -} -function wk_pause { - param([string]$message = "Press Enter to continue... ") - Write-Host $message - $x = read-host -} - -## Download ## -$path = $tmp - -# 7-Zip -$url = "http://www.7-zip.org/a/7z1701.msi" -download-file $path "7z-installer.msi" $url -$url = "http://www.7-zip.org/a/7z1701-extra.7z" -download-file $path "7z-extra.7z" $url - -# ConEmu -$url = "https://github.com/Maximus5/ConEmu/releases/download/v17.11.09/ConEmuPack.171109.7z" -download-file $path "ConEmuPack.7z" $url - -# Notepad++ -$url = "https://notepad-plus-plus.org/repository/7.x/7.5.1/npp.7.5.1.bin.minimalist.7z" -download-file $path "npp.7z" $url - -# Python -$url = "https://www.python.org/ftp/python/3.6.3/python-3.6.3-embed-win32.zip" -download-file $path "python32.zip" $url -$url = "https://www.python.org/ftp/python/3.6.3/python-3.6.3-embed-amd64.zip" -download-file $path "python64.zip" $url - -# Python: psutil -$dl_page = "https://pypi.python.org/pypi/psutil" -$regex = "href=.*-cp36-cp36m-win32.whl" -$url = find-dynamic-url $dl_page $regex -download-file $path "psutil32.whl" $url -$regex = "href=.*-cp36-cp36m-win_amd64.whl" -$url = find-dynamic-url $dl_page $regex -download-file $path "psutil64.whl" $url - -# Python: requests & dependancies -$regex = "href=.*.py3-none-any.whl" -foreach ($mod in @("chardet", "certifi", "idna", "urllib3", "requests")) { - $dl_page = "https://pypi.python.org/pypi/{0}" -f $mod - $name = "{0}.whl" -f $mod - $url = find-dynamic-url $dl_page $regex - download-file $path $name $url -} - -## Extract ## -# 7-Zip -Write-Host "Extracting: 7-Zip" -try { - start "msiexec" -argumentlist @("/a", "$tmp\7z-installer.msi", "TARGETDIR=$tmp\7zi", "/qn") -wait - $sz = "$tmp\7zi\Files\7-Zip\7z.exe" - start $sz -argumentlist @("x", "$tmp\7z-extra.7z", "-o$bin\7-Zip", "-aoa", "-bso0", "-bse0", "-bsp0", "-x!x64\*.dll", "-x!Far", "-x!*.dll") -nonewwindow -wait - Start-Sleep 1 - Move-Item "$bin\7-Zip\x64\7za.exe" "$bin\7-Zip\7za64.exe" - Remove-Item "$bin\7-Zip\x64" -Recurse - Remove-Item "$tmp\7z*" -Recurse - $sz = "$bin\7-Zip\7za.exe" -} -catch { - Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" -} - -# Notepad++ -Write-Host "Extracting: Notepad++" -try { - start $sz -argumentlist @("x", "$tmp\npp.7z", "-o$bin\NotepadPlusPlus", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait - Remove-Item "$tmp\npp.7z" - Move-Item "$bin\NotepadPlusPlus\notepad++.exe" "$bin\NotepadPlusPlus\notepadplusplus.exe" -} -catch { - Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" -} - -# ConEmu -Write-Host "Extracting: ConEmu" -try { - start $sz -argumentlist @("x", "$tmp\ConEmuPack.7z", "-o$bin\ConEmu", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait - Remove-Item "$tmp\ConEmuPack.7z" -} -catch { - Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" -} - -# Python x32 -Write-Host "Extracting: Python (x32)" -try { - foreach ($file in @("python32.zip", "certifi.whl", "chardet.whl", "idna.whl", "psutil32.whl", "requests.whl", "urllib3.whl")) { - start $sz -argumentlist @("x", "$tmp\$file", "-o$bin\Python\x32", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait - } -} -catch { - Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" -} - -# Python x64 -Write-Host "Extracting: Python (x64)" -try { - foreach ($file in @("python64.zip", "certifi.whl", "chardet.whl", "idna.whl", "psutil64.whl", "requests.whl", "urllib3.whl")) { - start $sz -argumentlist @("x", "$tmp\$file", "-o$bin\Python\x64", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait - } - Remove-Item "$tmp\python*.zip" - Remove-Item "$tmp\*.whl" -} -catch { - Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" -} - -## Configure ## -Write-Host "Configuring kit" -wk_pause "Press Enter to open settings..." -start "$bin\NotepadPlusPlus\notepadplusplus.exe" -argumentlist @("$bin\Scripts\settings\main.py") -wait -Start-Sleep 1 - -## Done ## -popd -if ($errors -gt 0) { - wk_pause "Press Enter to exit..." -} else { - start "$bin\ConEmu\ConEmu.exe" -argumentlist @("-run", "$bin\Python\x32\python.exe", "$bin\Scripts\update_kit.py", "-new_console:n") -verb Runas -} +# Wizard Kit: Download kit components + +## Init ## +clear +$host.UI.RawUI.WindowTitle = "Wizard Kit: Build Tool" +$wd = $(Split-Path $MyInvocation.MyCommand.Path) +$bin = (Get-Item $wd).Parent.FullName +$root = (Get-Item "$bin\..").FullName # Get-Item $bin fails + # (I'm assuming that starting with a '.' is the issue) +$tmp = "{0}\tmp" -f $bin +$errors = 0 +pushd "$wd" +$host.UI.RawUI.BackgroundColor = "black" +$host.UI.RawUI.ForegroundColor = "white" +$progressPreference = 'silentlyContinue' + +## Functions ## +function download-file { + param ([String]$path, [String]$name, [String]$url) + $outfile = "{0}\{1}" -f $path, $name + + Write-Host ("Downloading: {0}" -f $name) + New-Item -Type Directory $path 2>&1 | Out-Null + try { + invoke-webrequest -uri $url -outfile $outfile + } + catch { + Write-Host (" ERROR: Failed to download file." ) -foregroundcolor "Red" + $errors += 1 + } +} +function find-dynamic-url { + param ([String]$source_page, [String]$regex) + $d_url = "" + + # Get source page + invoke-webrequest -uri $source_page -outfile "tmp_page" + + # Search for real url + $d_url = Get-Content "tmp_page" | Where-Object {$_ -imatch $regex} + $d_url = $d_url -ireplace '.*(a |)href="([^"]+)".*', '$2' + $d_url = $d_url -ireplace ".*(a |)href='([^']+)'.*", '$2' + + # Remove tmp_page + Remove-Item "tmp_page" + + return $d_url +} +function wk_pause { + param([string]$message = "Press Enter to continue... ") + Write-Host $message + $x = read-host +} + +## Download ## +$path = $tmp + +# 7-Zip +$url = "http://www.7-zip.org/a/7z1701.msi" +download-file $path "7z-installer.msi" $url +$url = "http://www.7-zip.org/a/7z1701-extra.7z" +download-file $path "7z-extra.7z" $url + +# ConEmu +$url = "https://github.com/Maximus5/ConEmu/releases/download/v17.11.09/ConEmuPack.171109.7z" +download-file $path "ConEmuPack.7z" $url + +# Notepad++ +$url = "https://notepad-plus-plus.org/repository/7.x/7.5.1/npp.7.5.1.bin.minimalist.7z" +download-file $path "npp.7z" $url + +# Python +$url = "https://www.python.org/ftp/python/3.6.3/python-3.6.3-embed-win32.zip" +download-file $path "python32.zip" $url +$url = "https://www.python.org/ftp/python/3.6.3/python-3.6.3-embed-amd64.zip" +download-file $path "python64.zip" $url + +# Python: psutil +$dl_page = "https://pypi.python.org/pypi/psutil" +$regex = "href=.*-cp36-cp36m-win32.whl" +$url = find-dynamic-url $dl_page $regex +download-file $path "psutil32.whl" $url +$regex = "href=.*-cp36-cp36m-win_amd64.whl" +$url = find-dynamic-url $dl_page $regex +download-file $path "psutil64.whl" $url + +# Python: requests & dependancies +$regex = "href=.*.py3-none-any.whl" +foreach ($mod in @("chardet", "certifi", "idna", "urllib3", "requests")) { + $dl_page = "https://pypi.python.org/pypi/{0}" -f $mod + $name = "{0}.whl" -f $mod + $url = find-dynamic-url $dl_page $regex + download-file $path $name $url +} + +## Extract ## +# 7-Zip +Write-Host "Extracting: 7-Zip" +try { + start "msiexec" -argumentlist @("/a", "$tmp\7z-installer.msi", "TARGETDIR=$tmp\7zi", "/qn") -wait + $sz = "$tmp\7zi\Files\7-Zip\7z.exe" + start $sz -argumentlist @("x", "$tmp\7z-extra.7z", "-o$bin\7-Zip", "-aoa", "-bso0", "-bse0", "-bsp0", "-x!x64\*.dll", "-x!Far", "-x!*.dll") -nonewwindow -wait + Start-Sleep 1 + Move-Item "$bin\7-Zip\x64\7za.exe" "$bin\7-Zip\7za64.exe" + Remove-Item "$bin\7-Zip\x64" -Recurse + Remove-Item "$tmp\7z*" -Recurse + $sz = "$bin\7-Zip\7za.exe" +} +catch { + Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" +} + +# Notepad++ +Write-Host "Extracting: Notepad++" +try { + start $sz -argumentlist @("x", "$tmp\npp.7z", "-o$bin\NotepadPlusPlus", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait + Remove-Item "$tmp\npp.7z" + Move-Item "$bin\NotepadPlusPlus\notepad++.exe" "$bin\NotepadPlusPlus\notepadplusplus.exe" +} +catch { + Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" +} + +# ConEmu +Write-Host "Extracting: ConEmu" +try { + start $sz -argumentlist @("x", "$tmp\ConEmuPack.7z", "-o$bin\ConEmu", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait + Remove-Item "$tmp\ConEmuPack.7z" +} +catch { + Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" +} + +# Python x32 +Write-Host "Extracting: Python (x32)" +try { + foreach ($file in @("python32.zip", "certifi.whl", "chardet.whl", "idna.whl", "psutil32.whl", "requests.whl", "urllib3.whl")) { + start $sz -argumentlist @("x", "$tmp\$file", "-o$bin\Python\x32", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait + } +} +catch { + Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" +} + +# Python x64 +Write-Host "Extracting: Python (x64)" +try { + foreach ($file in @("python64.zip", "certifi.whl", "chardet.whl", "idna.whl", "psutil64.whl", "requests.whl", "urllib3.whl")) { + start $sz -argumentlist @("x", "$tmp\$file", "-o$bin\Python\x64", "-aoa", "-bso0", "-bse0", "-bsp0") -nonewwindow -wait + } + Remove-Item "$tmp\python*.zip" + Remove-Item "$tmp\*.whl" +} +catch { + Write-Host (" ERROR: Failed to extract files." ) -foregroundcolor "Red" +} + +## Configure ## +Write-Host "Configuring kit" +wk_pause "Press Enter to open settings..." +start "$bin\NotepadPlusPlus\notepadplusplus.exe" -argumentlist @("$bin\Scripts\settings\main.py") -wait +Start-Sleep 1 + +## Done ## +popd +if ($errors -gt 0) { + wk_pause "Press Enter to exit..." +} else { + start "$bin\ConEmu\ConEmu.exe" -argumentlist @("-run", "$bin\Python\x32\python.exe", "$bin\Scripts\update_kit.py", "-new_console:n") -verb Runas +} diff --git a/.bin/Scripts/cbs_fix.py b/.bin/Scripts/cbs_fix.py index 4d4f4db2..d0ef981e 100644 --- a/.bin/Scripts/cbs_fix.py +++ b/.bin/Scripts/cbs_fix.py @@ -1,42 +1,42 @@ -# Wizard Kit: Backup CBS Logs and prep CBS temp data for deletion - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.cleanup import * -from functions.data import * -init_global_vars() -os.system('title {}: CBS Cleanup'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\CBS Cleanup.log'.format(**global_vars) - -if __name__ == '__main__': - try: - # Prep - stay_awake() - os.system('cls') - folder_path = r'{}\Backups'.format(KIT_NAME_SHORT) - dest = select_destination(folder_path=folder_path, - prompt='Which disk are we using for temp data and backup?') - - # Show details - print_info('{}: CBS Cleanup Tool\n'.format(KIT_NAME_FULL)) - show_info('Backup / Temp path:', dest) - print_standard('\n') - if (not ask('Proceed with CBS cleanup?')): - abort() - - # Run Cleanup - try_and_print(message='Running cleanup...', function=cleanup_cbs, - cs='Done', dest_folder=dest) - - # Done - print_standard('\nDone.') - pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Backup CBS Logs and prep CBS temp data for deletion + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.cleanup import * +from functions.data import * +init_global_vars() +os.system('title {}: CBS Cleanup'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\CBS Cleanup.log'.format(**global_vars) + +if __name__ == '__main__': + try: + # Prep + stay_awake() + os.system('cls') + folder_path = r'{}\Backups'.format(KIT_NAME_SHORT) + dest = select_destination(folder_path=folder_path, + prompt='Which disk are we using for temp data and backup?') + + # Show details + print_info('{}: CBS Cleanup Tool\n'.format(KIT_NAME_FULL)) + show_info('Backup / Temp path:', dest) + print_standard('\n') + if (not ask('Proceed with CBS cleanup?')): + abort() + + # Run Cleanup + try_and_print(message='Running cleanup...', function=cleanup_cbs, + cs='Done', dest_folder=dest) + + # Done + print_standard('\nDone.') + pause("Press Enter to exit...") + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/check_disk.py b/.bin/Scripts/check_disk.py index f1cbb0ab..10931de9 100644 --- a/.bin/Scripts/check_disk.py +++ b/.bin/Scripts/check_disk.py @@ -1,56 +1,56 @@ -# Wizard Kit: Check or repair the %SYSTEMDRIVE% filesystem via CHKDSK - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.repairs import * -init_global_vars() -os.system('title {}: Check Disk Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\Check Disk.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }, - 'Warning': { - 'GenericRepair': 'Repaired', - 'UnsupportedOSError': 'Unsupported OS', - }} - options = [ - {'Name': 'Run CHKDSK scan (read-only)', 'Repair': False}, - {'Name': 'Schedule CHKDSK scan (offline repair)', 'Repair': True}] - actions = [{'Name': 'Quit', 'Letter': 'Q'}] - selection = menu_select( - '{}: Check Disk Menu\n'.format(KIT_NAME_FULL), - main_entries=options, - action_entries=actions) - print_info('{}: Check Disk Menu\n'.format(KIT_NAME_FULL)) - if selection == 'Q': - abort() - elif selection.isnumeric(): - repair = options[int(selection)-1]['Repair'] - if repair: - cs = 'Scheduled' - else: - cs = 'CS' - message = 'CHKDSK ({SYSTEMDRIVE})...'.format(**global_vars['Env']) - try_and_print(message=message, function=run_chkdsk, - cs=cs, other_results=other_results, repair=repair) - else: - abort() - - # Done - print_success('Done.') - pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Check or repair the %SYSTEMDRIVE% filesystem via CHKDSK + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.repairs import * +init_global_vars() +os.system('title {}: Check Disk Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\Check Disk.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }, + 'Warning': { + 'GenericRepair': 'Repaired', + 'UnsupportedOSError': 'Unsupported OS', + }} + options = [ + {'Name': 'Run CHKDSK scan (read-only)', 'Repair': False}, + {'Name': 'Schedule CHKDSK scan (offline repair)', 'Repair': True}] + actions = [{'Name': 'Quit', 'Letter': 'Q'}] + selection = menu_select( + '{}: Check Disk Menu\n'.format(KIT_NAME_FULL), + main_entries=options, + action_entries=actions) + print_info('{}: Check Disk Menu\n'.format(KIT_NAME_FULL)) + if selection == 'Q': + abort() + elif selection.isnumeric(): + repair = options[int(selection)-1]['Repair'] + if repair: + cs = 'Scheduled' + else: + cs = 'CS' + message = 'CHKDSK ({SYSTEMDRIVE})...'.format(**global_vars['Env']) + try_and_print(message=message, function=run_chkdsk, + cs=cs, other_results=other_results, repair=repair) + else: + abort() + + # Done + print_success('Done.') + pause("Press Enter to exit...") + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/compress_bin.cmd b/.bin/Scripts/compress_bin.cmd index ed697a8b..e29b6445 100644 --- a/.bin/Scripts/compress_bin.cmd +++ b/.bin/Scripts/compress_bin.cmd @@ -1,28 +1,28 @@ -@echo off - -setlocal enabledelayedexpansion -pushd "%~dp0" - -rem Prep -mkdir _out\_Drivers -set "out=%cd%\_out" - -rem _Drivers -pushd _Drivers -for %%f in (*) do ( - set "file=%%f" - "%programfiles%\7-Zip\7z.exe" a -t7z -mx=9 -myx=9 -ms=on -mhe -pAbracadabra "%out%\_Drivers\!file:~0,-4!.7z" "%%f" -) -popd - -rem Rest -for /d %%d in (*) do ( - if not "%%d" == "_out" ( - pushd "%%d" - "%programfiles%\7-Zip\7z.exe" a -t7z -mx=9 -myx=9 -ms=on -mhe -pAbracadabra "%out%\%%d.7z" * - popd - ) -) - -popd +@echo off + +setlocal enabledelayedexpansion +pushd "%~dp0" + +rem Prep +mkdir _out\_Drivers +set "out=%cd%\_out" + +rem _Drivers +pushd _Drivers +for %%f in (*) do ( + set "file=%%f" + "%programfiles%\7-Zip\7z.exe" a -t7z -mx=9 -myx=9 -ms=on -mhe -pAbracadabra "%out%\_Drivers\!file:~0,-4!.7z" "%%f" +) +popd + +rem Rest +for /d %%d in (*) do ( + if not "%%d" == "_out" ( + pushd "%%d" + "%programfiles%\7-Zip\7z.exe" a -t7z -mx=9 -myx=9 -ms=on -mhe -pAbracadabra "%out%\%%d.7z" * + popd + ) +) + +popd endlocal \ No newline at end of file diff --git a/.bin/Scripts/dism.py b/.bin/Scripts/dism.py index 5d969ec2..4f33f63e 100644 --- a/.bin/Scripts/dism.py +++ b/.bin/Scripts/dism.py @@ -1,57 +1,57 @@ -# Wizard Kit: Check or repair component store health via DISM - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.repairs import * -init_global_vars() -os.system('title {}: DISM helper Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\DISM helper tool.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }, - 'Warning': { - 'GenericRepair': 'Repaired', - 'UnsupportedOSError': 'Unsupported OS', - }} - disabled = bool(global_vars['OS']['Version'] not in ['8', '10']) - options = [ - {'Name': 'Check Health', 'Repair': False, 'Disabled': disabled}, - {'Name': 'Restore Health', 'Repair': True, 'Disabled': disabled}] - actions = [{'Name': 'Quit', 'Letter': 'Q'}] - selection = menu_select( - '{}: DISM Menu\n'.format(KIT_NAME_FULL), - main_entries=options, - action_entries=actions) - print_info('{}: DISM Menu\n'.format(KIT_NAME_FULL)) - if selection == 'Q': - abort() - elif selection.isnumeric(): - repair = options[int(selection)-1]['Repair'] - if repair: - message='DISM RestoreHealth...' - else: - message='DISM ScanHealth...' - try_and_print(message=message, function=run_dism, - cs='No corruption', ns='Corruption detected', - other_results=other_results, repair=repair) - else: - abort() - - # Done - print_success('Done.') - pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Check or repair component store health via DISM + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.repairs import * +init_global_vars() +os.system('title {}: DISM helper Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\DISM helper tool.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }, + 'Warning': { + 'GenericRepair': 'Repaired', + 'UnsupportedOSError': 'Unsupported OS', + }} + disabled = bool(global_vars['OS']['Version'] not in ['8', '10']) + options = [ + {'Name': 'Check Health', 'Repair': False, 'Disabled': disabled}, + {'Name': 'Restore Health', 'Repair': True, 'Disabled': disabled}] + actions = [{'Name': 'Quit', 'Letter': 'Q'}] + selection = menu_select( + '{}: DISM Menu\n'.format(KIT_NAME_FULL), + main_entries=options, + action_entries=actions) + print_info('{}: DISM Menu\n'.format(KIT_NAME_FULL)) + if selection == 'Q': + abort() + elif selection.isnumeric(): + repair = options[int(selection)-1]['Repair'] + if repair: + message='DISM RestoreHealth...' + else: + message='DISM ScanHealth...' + try_and_print(message=message, function=run_dism, + cs='No corruption', ns='Corruption detected', + other_results=other_results, repair=repair) + else: + abort() + + # Done + print_success('Done.') + pause("Press Enter to exit...") + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/functions/activation.py b/.bin/Scripts/functions/activation.py index f54d1dca..3eea560c 100644 --- a/.bin/Scripts/functions/activation.py +++ b/.bin/Scripts/functions/activation.py @@ -1,66 +1,66 @@ -# Wizard Kit: Functions - Activation - -import subprocess - -from borrowed import acpi -from functions.common import * -from os import environ - -# Variables -SLMGR = r'{}\System32\slmgr.vbs'.format(environ.get('SYSTEMROOT')) - -def activate_with_bios(): - """Attempt to activate Windows with a key stored in the BIOS.""" - # Code borrowed from https://github.com/aeruder/get_win8key - ##################################################### - #script to query windows 8.x OEM key from PC firmware - #ACPI -> table MSDM -> raw content -> byte offset 56 to end - #ck, 03-Jan-2014 (christian@korneck.de) - ##################################################### - bios_key = None - table = b"MSDM" - if acpi.FindAcpiTable(table) is True: - rawtable = acpi.GetAcpiTable(table) - #http://msdn.microsoft.com/library/windows/hardware/hh673514 - #byte offset 36 from beginning \ - # = Microsoft 'software licensing data structure' \ - # / 36 + 20 bytes offset from beginning = Win Key - bios_key = rawtable[56:len(rawtable)].decode("utf-8") - if bios_key is None: - raise BIOSKeyNotFoundError - - # Install Key - cmd = ['cscript', '//nologo', SLMGR, '/ipk', bios_key] - subprocess.run(cmd, check=False) - sleep(5) - - # Attempt activation - cmd = ['cscript', '//nologo', SLMGR, '/ato'] - subprocess.run(cmd, check=False) - sleep(5) - - # Check status - if not windows_is_activated(): - raise Exception('Activation Failed') - -def get_activation_string(): - """Get activation status, returns str.""" - act_str = subprocess.run( - ['cscript', '//nologo', SLMGR, '/xpr'], check=False, - stdout=subprocess.PIPE, stderr=subprocess.PIPE) - act_str = act_str.stdout.decode() - act_str = act_str.splitlines() - act_str = act_str[1].strip() - return act_str - -def windows_is_activated(): - """Check if Windows is activated via slmgr.vbs and return bool.""" - activation_string = subprocess.run( - ['cscript', '//nologo', SLMGR, '/xpr'], check=False, - stdout=subprocess.PIPE, stderr=subprocess.PIPE) - activation_string = activation_string.stdout.decode() - - return bool(activation_string and 'permanent' in activation_string) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Activation + +import subprocess + +from borrowed import acpi +from functions.common import * +from os import environ + +# Variables +SLMGR = r'{}\System32\slmgr.vbs'.format(environ.get('SYSTEMROOT')) + +def activate_with_bios(): + """Attempt to activate Windows with a key stored in the BIOS.""" + # Code borrowed from https://github.com/aeruder/get_win8key + ##################################################### + #script to query windows 8.x OEM key from PC firmware + #ACPI -> table MSDM -> raw content -> byte offset 56 to end + #ck, 03-Jan-2014 (christian@korneck.de) + ##################################################### + bios_key = None + table = b"MSDM" + if acpi.FindAcpiTable(table) is True: + rawtable = acpi.GetAcpiTable(table) + #http://msdn.microsoft.com/library/windows/hardware/hh673514 + #byte offset 36 from beginning \ + # = Microsoft 'software licensing data structure' \ + # / 36 + 20 bytes offset from beginning = Win Key + bios_key = rawtable[56:len(rawtable)].decode("utf-8") + if bios_key is None: + raise BIOSKeyNotFoundError + + # Install Key + cmd = ['cscript', '//nologo', SLMGR, '/ipk', bios_key] + subprocess.run(cmd, check=False) + sleep(5) + + # Attempt activation + cmd = ['cscript', '//nologo', SLMGR, '/ato'] + subprocess.run(cmd, check=False) + sleep(5) + + # Check status + if not windows_is_activated(): + raise Exception('Activation Failed') + +def get_activation_string(): + """Get activation status, returns str.""" + act_str = subprocess.run( + ['cscript', '//nologo', SLMGR, '/xpr'], check=False, + stdout=subprocess.PIPE, stderr=subprocess.PIPE) + act_str = act_str.stdout.decode() + act_str = act_str.splitlines() + act_str = act_str[1].strip() + return act_str + +def windows_is_activated(): + """Check if Windows is activated via slmgr.vbs and return bool.""" + activation_string = subprocess.run( + ['cscript', '//nologo', SLMGR, '/xpr'], check=False, + stdout=subprocess.PIPE, stderr=subprocess.PIPE) + activation_string = activation_string.stdout.decode() + + return bool(activation_string and 'permanent' in activation_string) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/browsers.py b/.bin/Scripts/functions/browsers.py index e4df7c41..98073bba 100644 --- a/.bin/Scripts/functions/browsers.py +++ b/.bin/Scripts/functions/browsers.py @@ -1,447 +1,447 @@ -# Wizard Kit: Functions - Browsers - -from functions.common import * - -# Define other_results for later try_and_print -browser_data = {} -other_results = { - 'Error': { - 'MultipleInstallationsError': 'Multiple installations detected', - }, - 'Warning': { - 'NotInstalledError': 'Not installed', - 'NoProfilesError': 'No profiles found', - } -} - -# Regex -REGEX_BACKUP = re.compile( - r'\.\w+bak.*', - re.IGNORECASE) -REGEX_CHROMIUM_PROFILE = re.compile( - r'^(Default|Profile)', - re.IGNORECASE) -REGEX_CHROMIUM_ITEMS = re.compile( - r'^(Bookmarks|Cookies|Favicons|Google Profile' - r'|History|Login Data|Top Sites|TransportSecurity' - r'|Visited Links|Web Data)', - re.IGNORECASE) -REGEX_MOZILLA = re.compile( - r'^(bookmarkbackups|(cookies|formhistory|places).sqlite' - r'|key3.db|logins.json|persdict.dat)$', - re.IGNORECASE) - -# STATIC VARIABLES -DEFAULT_HOMEPAGE = 'https://www.google.com/' -IE_GALLERY = 'https://www.microsoft.com/en-us/iegallery' -MOZILLA_PREFS = { - 'browser.search.defaultenginename': '"Google"', - 'browser.search.defaultenginename.US': '"Google"', - 'browser.search.geoSpecificDefaults': 'false', - 'browser.startup.homepage': '"{}"'.format(DEFAULT_HOMEPAGE), - 'extensions.ui.lastCategory': '"addons://list/extension"', - } -UBO_CHROME = 'https://chrome.google.com/webstore/detail/ublock-origin/cjpalhdlnbpafiamejdnhcphjbkeiagm?hl=en' -UBO_CHROME_REG = r'Software\Wow6432Node\Google\Chrome\Extensions\cjpalhdlnbpafiamejdnhcphjbkeiagm' -UBO_EXTRA_CHROME = 'https://chrome.google.com/webstore/detail/ublock-origin-extra/pgdnlhfefecpicbbihgmbmffkjpaplco?hl=en' -UBO_EXTRA_CHROME_REG = r'Software\Wow6432Node\Google\Chrome\Extensions\pgdnlhfefecpicbbihgmbmffkjpaplco' -UBO_MOZILLA = 'https://addons.mozilla.org/en-us/firefox/addon/ublock-origin/' -UBO_OPERA = 'https://addons.opera.com/en/extensions/details/ublock/?display=en' -SUPPORTED_BROWSERS = { - 'Internet Explorer': { - 'base': 'ie', - 'exe_name': 'iexplore.exe', - 'rel_install_path': 'Internet Explorer', - 'user_data_path': r'{USERPROFILE}\Favorites', - }, - 'Google Chrome': { - 'base': 'chromium', - 'exe_name': 'chrome.exe', - 'rel_install_path': r'Google\Chrome\Application', - 'user_data_path': r'{LOCALAPPDATA}\Google\Chrome\User Data', - }, - 'Google Chrome Canary': { - 'base': 'chromium', - 'exe_name': 'chrome.exe', - 'rel_install_path': r'Google\Chrome SxS\Application', - 'user_data_path': r'{LOCALAPPDATA}\Google\Chrome SxS\User Data', - }, - 'Mozilla Firefox': { - 'base': 'mozilla', - 'exe_name': 'firefox.exe', - 'rel_install_path': 'Mozilla Firefox', - 'user_data_path': r'{APPDATA}\Mozilla\Firefox\Profiles', - }, - 'Mozilla Firefox Dev': { - 'base': 'mozilla', - 'exe_name': 'firefox.exe', - 'rel_install_path': 'Firefox Developer Edition', - 'user_data_path': r'{APPDATA}\Mozilla\Firefox\Profiles', - }, - 'Opera': { - 'base': 'chromium', - 'exe_name': 'launcher.exe', - 'rel_install_path': 'Opera', - 'user_data_path': r'{APPDATA}\Opera Software\Opera Stable', - }, - 'Opera Beta': { - 'base': 'chromium', - 'exe_name': 'launcher.exe', - 'rel_install_path': 'Opera beta', - 'user_data_path': r'{APPDATA}\Opera Software\Opera Next', - }, - 'Opera Dev': { - 'base': 'chromium', - 'exe_name': 'launcher.exe', - 'rel_install_path': 'Opera developer', - 'user_data_path': r'{APPDATA}\Opera Software\Opera Developer', - }, - } - -def archive_browser(name): - """Create backup of Browser saved in the BackupDir.""" - source = '{}*'.format(browser_data[name]['user_data_path']) - dest = r'{BackupDir}\Browsers ({USERNAME})'.format( - **global_vars, **global_vars['Env']) - archive = r'{}\{}.7z'.format(dest, name) - os.makedirs(dest, exist_ok=True) - cmd = [ - global_vars['Tools']['SevenZip'], - 'a', '-aoa', '-bso0', '-bse0', '-mx=1', - archive, source] - run_program(cmd) - -def backup_browsers(): - """Create backup of all detected browsers.""" - for name in sorted(browser_data): - try_and_print(message='{}...'.format(name), - function=archive_browser, name=name) - -def clean_chromium_profile(profile): - """Renames profile, creates a new folder, and copies the user data to it.""" - if profile is None: - raise Exception - backup_path = '{path}_{Date}.bak'.format( - path=profile['path'], **global_vars) - backup_path = non_clobber_rename(backup_path) - shutil.move(profile['path'], backup_path) - os.makedirs(profile['path'], exist_ok=True) - - # Restore essential files from backup_path - for entry in os.scandir(backup_path): - if REGEX_CHROMIUM_ITEMS.search(entry.name): - shutil.copy(entry.path, r'{}\{}'.format( - profile['path'], entry.name)) - -def clean_internet_explorer(**kwargs): - """Uses the built-in function to reset IE and sets the homepage. - - NOTE: kwargs set but unused as a workaround.""" - kill_process('iexplore.exe') - run_program(['rundll32.exe', 'inetcpl.cpl,ResetIEtoDefaults'], check=False) - key = r'Software\Microsoft\Internet Explorer\Main' - - # Set homepage - with winreg.OpenKey(HKCU, key, access=winreg.KEY_WRITE) as _key: - winreg.SetValueEx(_key, 'Start Page', 0, - winreg.REG_SZ, DEFAULT_HOMEPAGE) - try: - winreg.DeleteValue(_key, 'Secondary Start Pages') - except FileNotFoundError: - pass - -def clean_mozilla_profile(profile): - """Renames profile, creates a new folder, and copies the user data to it.""" - if profile is None: - raise Exception - backup_path = '{path}_{Date}.bak'.format( - path=profile['path'], **global_vars) - backup_path = non_clobber_rename(backup_path) - shutil.move(profile['path'], backup_path) - homepages = [] - os.makedirs(profile['path'], exist_ok=True) - - # Restore essential files from backup_path - for entry in os.scandir(backup_path): - if REGEX_MOZILLA.search(entry.name): - if entry.is_dir(): - shutil.copytree(entry.path, r'{}\{}'.format( - profile['path'], entry.name)) - else: - shutil.copy(entry.path, r'{}\{}'.format( - profile['path'], entry.name)) - - # Set profile defaults - with open(r'{path}\prefs.js'.format(**profile), 'a', encoding='ascii') as f: - for k, v in MOZILLA_PREFS.items(): - f.write('user_pref("{}", {});\n'.format(k, v)) - -def get_browser_details(name): - """Get installation status and profile details for all supported browsers.""" - browser = SUPPORTED_BROWSERS[name].copy() - - # Update user_data_path - browser['user_data_path'] = browser['user_data_path'].format( - **global_vars['Env']) - - # Find executable (if multiple files are found, the last one is used) - exe_path = None - num_installs = 0 - for install_path in ['LOCALAPPDATA', 'PROGRAMFILES(X86)', 'PROGRAMFILES']: - test_path = r'{install_path}\{rel_install_path}\{exe_name}'.format( - install_path = global_vars['Env'].get(install_path, ''), - **browser) - if os.path.exists(test_path): - num_installs += 1 - exe_path = test_path - - # Find profile(s) - profiles = [] - if browser['base'] == 'ie': - profiles.append({'name': 'Default', 'path': None}) - elif 'Google Chrome' in name: - profiles.extend( - get_chromium_profiles( - search_path=browser['user_data_path'])) - elif browser['base'] == 'mozilla': - dev = 'Dev' in name - profiles.extend( - get_mozilla_profiles( - search_path=browser['user_data_path'], dev=dev)) - if exe_path and not dev and len(profiles) == 0: - # e.g. If Firefox is installed but no profiles were found. - ## Rename profiles.ini and create a new default profile - profiles_ini_path = browser['user_data_path'].replace( - 'Profiles', 'profiles.ini') - if os.path.exists(profiles_ini_path): - backup_path = '{path}_{Date}.bak'.format( - path=profiles_ini_path, **global_vars) - backup_path = non_clobber_rename(backup_path) - shutil.move(profiles_ini_path, backup_path) - run_program([exe_path, '-createprofile', 'default'], check=False) - profiles.extend( - get_mozilla_profiles( - search_path=browser['user_data_path'], dev=dev)) - - elif 'Opera' in name: - if os.path.exists(browser['user_data_path']): - profiles.append( - {'name': 'Default', 'path': browser['user_data_path']}) - - # Skip browser if there's no profiles - if len(profiles) == 0: - raise NoProfilesError - - # Get homepages - if browser['base'] == 'ie': - # IE is set to only have one profile above - profiles[0]['homepages'] = get_ie_homepages() - elif browser['base'] == 'mozilla': - for profile in profiles: - prefs_path = r'{path}\prefs.js'.format(**profile) - profile['homepages'] = get_mozilla_homepages(prefs_path=prefs_path) - - # Add to browser_data - browser_data[name] = browser - browser_data[name].update({ - 'exe_path': exe_path, - 'profiles': profiles, - }) - - # Raise installation warnings (if any) - if num_installs == 0: - raise NotInstalledError - elif num_installs > 1 and browser['base'] != 'ie': - raise MultipleInstallationsError - -def get_chromium_profiles(search_path): - """Find any chromium-style profiles and return as a list of dicts.""" - profiles = [] - try: - for entry in os.scandir(search_path): - if entry.is_dir() and REGEX_CHROMIUM_PROFILE.search(entry.name): - profiles.append(entry) - REGEX_PROFILE_BACKUP = r'\.\w+bak.*' - profiles = [p for p in profiles if not REGEX_BACKUP.search(p.name)] - # Convert os.DirEntries to dicts - profiles = [{'name': p.name, 'path': p.path} for p in profiles] - except Exception: - pass - - return profiles - -def get_ie_homepages(): - """Read homepages from the registry and return as a list.""" - homepages = [] - main_page = '' - extra_pages = [] - key = r'Software\Microsoft\Internet Explorer\Main' - with winreg.OpenKey(HKCU, key) as _key: - try: - main_page = winreg.QueryValueEx(_key, 'Start Page')[0] - except FileNotFoundError: - pass - try: - extra_pages = winreg.QueryValueEx(_key, 'Secondary Start Pages')[0] - except FileNotFoundError: - pass - if main_page != '': - homepages.append(main_page) - if len(extra_pages) > 0: - homepages.extend(extra_pages) - return homepages - -def get_mozilla_homepages(prefs_path): - """Read homepages from prefs.js and return as a list.""" - homepages = [] - try: - with open(prefs_path, 'r') as f: - search = re.search( - r'browser\.startup\.homepage", "([^"]*)"', - f.read(), re.IGNORECASE) - if search: - homepages = search.group(1).split('|') - except Exception: - pass - - return homepages - -def get_mozilla_profiles(search_path, dev=False): - """Find any mozilla-style profiles and return as a list of dicts.""" - profiles = [] - try: - for entry in os.scandir(search_path): - if entry.is_dir(): - if 'dev-edition' in entry.name: - # NOTE: Not always present which can lead - # to Dev profiles being marked as non-Dev - ## NOTE 2: It is possible that a non-Dev profile - ## to be created with 'dev-edition' in the name. - ## (It wouldn't make sense, but possible) - if dev: - profiles.append(entry) - elif not dev: - profiles.append(entry) - profiles = [p for p in profiles if not REGEX_BACKUP.search(p.name)] - # Convert os.DirEntries to dicts - profiles = [{'name': p.name, 'path': p.path} for p in profiles] - except Exception: - pass - - return profiles - -def install_adblock(indent=8, width=32): - """Install adblock for all supported browsers.""" - for browser in sorted(browser_data): - exe_path = browser_data[browser].get('exe_path', None) - function=run_program - if exe_path is None: - print_standard( - '{indent}{browser:<{width}}'.format( - indent=' '*indent, width=width, browser=browser+'...'), - end='', flush=True) - print_warning('Not installed', timestamp=False) - else: - # Set urls to open - urls = [] - if browser_data[browser]['base'] == 'chromium': - if browser == 'Google Chrome': - # Check for system exensions - try: - winreg.QueryValue(HKLM, UBO_CHROME_REG) - except FileNotFoundError: - urls.append(UBO_CHROME) - try: - winreg.QueryValue(HKLM, UBO_EXTRA_CHROME_REG) - except FileNotFoundError: - urls.append(UBO_EXTRA_CHROME) - - if len(urls) == 0: - urls = ['chrome://extensions'] - elif 'Opera' in browser: - urls.append(UBO_OPERA) - else: - urls.append(UBO_CHROME) - urls.append(UBO_EXTRA_CHROME) - - elif browser_data[browser]['base'] == 'mozilla': - # Assume UBO is not installed first and change if it is - urls.append(UBO_MOZILLA) - if browser == 'Mozilla Firefox': - ubo = browser_data[browser]['exe_path'].replace( - 'firefox.exe', - r'distribution\extensions\uBlock0@raymondhill.net') - if os.path.exists(ubo): - urls = ['about:addons'] - - elif browser_data[browser]['base'] == 'ie': - urls.append(IE_GALLERY) - function=popen_program - - # By using check=False we're skipping any return codes so - # it should only fail if the program can't be run - # (or can't be found). - # In other words, this isn't tracking the addon/extension's - # installation status. - try_and_print(message='{}...'.format(browser), - indent=indent, width=width, - cs='Done', function=function, - cmd=[exe_path, *urls], check=False) - -def list_homepages(indent=8, width=32): - """List current homepages for reference.""" - - for browser in sorted(browser_data): - # Skip Chromium-based browsers - if browser_data[browser]['base'] == 'chromium': - print_info( - '{indent}{browser:<{width}}'.format( - indent=' '*indent, width=width, browser=browser+'...'), - end='', flush=True) - print_warning('Not implemented', timestamp=False) - continue - - # All other browsers - profiles = browser_data[browser].get('profiles', []) - if profiles: - print_info('{indent}{browser:<{width}}'.format( - indent=' '*indent, width=width, browser=browser+'...')) - for profile in profiles: - _name = profile.get('name', '?') - _homepages = profile.get('homepages', []) - if len(_homepages) == 0: - print_standard( - '{indent}{name:<{width}}'.format( - indent=' '*indent, width=width, name=_name), - end='', flush=True) - print_warning('None found', timestamp=False) - else: - for page in _homepages: - print_standard('{indent}{name:<{width}}{page}'.format( - indent=' '*indent, width=width, name=_name, page=page)) - -def reset_browsers(indent=8, width=32): - """Reset all detected browsers to safe defaults.""" - for browser in sorted(browser_data): - print_info('{indent}{name}'.format(indent=' '*indent, name=browser)) - for profile in browser_data[browser]['profiles']: - if browser_data[browser]['base'] == 'chromium': - function = clean_chromium_profile - elif browser_data[browser]['base'] == 'ie': - function = clean_internet_explorer - elif browser_data[browser]['base'] == 'mozilla': - function = clean_mozilla_profile - try_and_print( - message='{}...'.format(profile['name']), - indent=indent, width=width, function=function, - other_results=other_results, profile=profile) - -def scan_for_browsers(): - """Scan system for any supported browsers.""" - for name in sorted(SUPPORTED_BROWSERS): - try_and_print(message='{}...'.format(name), - function=get_browser_details, cs='Detected', - other_results=other_results, name=name) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Browsers + +from functions.common import * + +# Define other_results for later try_and_print +browser_data = {} +other_results = { + 'Error': { + 'MultipleInstallationsError': 'Multiple installations detected', + }, + 'Warning': { + 'NotInstalledError': 'Not installed', + 'NoProfilesError': 'No profiles found', + } +} + +# Regex +REGEX_BACKUP = re.compile( + r'\.\w+bak.*', + re.IGNORECASE) +REGEX_CHROMIUM_PROFILE = re.compile( + r'^(Default|Profile)', + re.IGNORECASE) +REGEX_CHROMIUM_ITEMS = re.compile( + r'^(Bookmarks|Cookies|Favicons|Google Profile' + r'|History|Login Data|Top Sites|TransportSecurity' + r'|Visited Links|Web Data)', + re.IGNORECASE) +REGEX_MOZILLA = re.compile( + r'^(bookmarkbackups|(cookies|formhistory|places).sqlite' + r'|key3.db|logins.json|persdict.dat)$', + re.IGNORECASE) + +# STATIC VARIABLES +DEFAULT_HOMEPAGE = 'https://www.google.com/' +IE_GALLERY = 'https://www.microsoft.com/en-us/iegallery' +MOZILLA_PREFS = { + 'browser.search.defaultenginename': '"Google"', + 'browser.search.defaultenginename.US': '"Google"', + 'browser.search.geoSpecificDefaults': 'false', + 'browser.startup.homepage': '"{}"'.format(DEFAULT_HOMEPAGE), + 'extensions.ui.lastCategory': '"addons://list/extension"', + } +UBO_CHROME = 'https://chrome.google.com/webstore/detail/ublock-origin/cjpalhdlnbpafiamejdnhcphjbkeiagm?hl=en' +UBO_CHROME_REG = r'Software\Wow6432Node\Google\Chrome\Extensions\cjpalhdlnbpafiamejdnhcphjbkeiagm' +UBO_EXTRA_CHROME = 'https://chrome.google.com/webstore/detail/ublock-origin-extra/pgdnlhfefecpicbbihgmbmffkjpaplco?hl=en' +UBO_EXTRA_CHROME_REG = r'Software\Wow6432Node\Google\Chrome\Extensions\pgdnlhfefecpicbbihgmbmffkjpaplco' +UBO_MOZILLA = 'https://addons.mozilla.org/en-us/firefox/addon/ublock-origin/' +UBO_OPERA = 'https://addons.opera.com/en/extensions/details/ublock/?display=en' +SUPPORTED_BROWSERS = { + 'Internet Explorer': { + 'base': 'ie', + 'exe_name': 'iexplore.exe', + 'rel_install_path': 'Internet Explorer', + 'user_data_path': r'{USERPROFILE}\Favorites', + }, + 'Google Chrome': { + 'base': 'chromium', + 'exe_name': 'chrome.exe', + 'rel_install_path': r'Google\Chrome\Application', + 'user_data_path': r'{LOCALAPPDATA}\Google\Chrome\User Data', + }, + 'Google Chrome Canary': { + 'base': 'chromium', + 'exe_name': 'chrome.exe', + 'rel_install_path': r'Google\Chrome SxS\Application', + 'user_data_path': r'{LOCALAPPDATA}\Google\Chrome SxS\User Data', + }, + 'Mozilla Firefox': { + 'base': 'mozilla', + 'exe_name': 'firefox.exe', + 'rel_install_path': 'Mozilla Firefox', + 'user_data_path': r'{APPDATA}\Mozilla\Firefox\Profiles', + }, + 'Mozilla Firefox Dev': { + 'base': 'mozilla', + 'exe_name': 'firefox.exe', + 'rel_install_path': 'Firefox Developer Edition', + 'user_data_path': r'{APPDATA}\Mozilla\Firefox\Profiles', + }, + 'Opera': { + 'base': 'chromium', + 'exe_name': 'launcher.exe', + 'rel_install_path': 'Opera', + 'user_data_path': r'{APPDATA}\Opera Software\Opera Stable', + }, + 'Opera Beta': { + 'base': 'chromium', + 'exe_name': 'launcher.exe', + 'rel_install_path': 'Opera beta', + 'user_data_path': r'{APPDATA}\Opera Software\Opera Next', + }, + 'Opera Dev': { + 'base': 'chromium', + 'exe_name': 'launcher.exe', + 'rel_install_path': 'Opera developer', + 'user_data_path': r'{APPDATA}\Opera Software\Opera Developer', + }, + } + +def archive_browser(name): + """Create backup of Browser saved in the BackupDir.""" + source = '{}*'.format(browser_data[name]['user_data_path']) + dest = r'{BackupDir}\Browsers ({USERNAME})'.format( + **global_vars, **global_vars['Env']) + archive = r'{}\{}.7z'.format(dest, name) + os.makedirs(dest, exist_ok=True) + cmd = [ + global_vars['Tools']['SevenZip'], + 'a', '-aoa', '-bso0', '-bse0', '-mx=1', + archive, source] + run_program(cmd) + +def backup_browsers(): + """Create backup of all detected browsers.""" + for name in sorted(browser_data): + try_and_print(message='{}...'.format(name), + function=archive_browser, name=name) + +def clean_chromium_profile(profile): + """Renames profile, creates a new folder, and copies the user data to it.""" + if profile is None: + raise Exception + backup_path = '{path}_{Date}.bak'.format( + path=profile['path'], **global_vars) + backup_path = non_clobber_rename(backup_path) + shutil.move(profile['path'], backup_path) + os.makedirs(profile['path'], exist_ok=True) + + # Restore essential files from backup_path + for entry in os.scandir(backup_path): + if REGEX_CHROMIUM_ITEMS.search(entry.name): + shutil.copy(entry.path, r'{}\{}'.format( + profile['path'], entry.name)) + +def clean_internet_explorer(**kwargs): + """Uses the built-in function to reset IE and sets the homepage. + + NOTE: kwargs set but unused as a workaround.""" + kill_process('iexplore.exe') + run_program(['rundll32.exe', 'inetcpl.cpl,ResetIEtoDefaults'], check=False) + key = r'Software\Microsoft\Internet Explorer\Main' + + # Set homepage + with winreg.OpenKey(HKCU, key, access=winreg.KEY_WRITE) as _key: + winreg.SetValueEx(_key, 'Start Page', 0, + winreg.REG_SZ, DEFAULT_HOMEPAGE) + try: + winreg.DeleteValue(_key, 'Secondary Start Pages') + except FileNotFoundError: + pass + +def clean_mozilla_profile(profile): + """Renames profile, creates a new folder, and copies the user data to it.""" + if profile is None: + raise Exception + backup_path = '{path}_{Date}.bak'.format( + path=profile['path'], **global_vars) + backup_path = non_clobber_rename(backup_path) + shutil.move(profile['path'], backup_path) + homepages = [] + os.makedirs(profile['path'], exist_ok=True) + + # Restore essential files from backup_path + for entry in os.scandir(backup_path): + if REGEX_MOZILLA.search(entry.name): + if entry.is_dir(): + shutil.copytree(entry.path, r'{}\{}'.format( + profile['path'], entry.name)) + else: + shutil.copy(entry.path, r'{}\{}'.format( + profile['path'], entry.name)) + + # Set profile defaults + with open(r'{path}\prefs.js'.format(**profile), 'a', encoding='ascii') as f: + for k, v in MOZILLA_PREFS.items(): + f.write('user_pref("{}", {});\n'.format(k, v)) + +def get_browser_details(name): + """Get installation status and profile details for all supported browsers.""" + browser = SUPPORTED_BROWSERS[name].copy() + + # Update user_data_path + browser['user_data_path'] = browser['user_data_path'].format( + **global_vars['Env']) + + # Find executable (if multiple files are found, the last one is used) + exe_path = None + num_installs = 0 + for install_path in ['LOCALAPPDATA', 'PROGRAMFILES(X86)', 'PROGRAMFILES']: + test_path = r'{install_path}\{rel_install_path}\{exe_name}'.format( + install_path = global_vars['Env'].get(install_path, ''), + **browser) + if os.path.exists(test_path): + num_installs += 1 + exe_path = test_path + + # Find profile(s) + profiles = [] + if browser['base'] == 'ie': + profiles.append({'name': 'Default', 'path': None}) + elif 'Google Chrome' in name: + profiles.extend( + get_chromium_profiles( + search_path=browser['user_data_path'])) + elif browser['base'] == 'mozilla': + dev = 'Dev' in name + profiles.extend( + get_mozilla_profiles( + search_path=browser['user_data_path'], dev=dev)) + if exe_path and not dev and len(profiles) == 0: + # e.g. If Firefox is installed but no profiles were found. + ## Rename profiles.ini and create a new default profile + profiles_ini_path = browser['user_data_path'].replace( + 'Profiles', 'profiles.ini') + if os.path.exists(profiles_ini_path): + backup_path = '{path}_{Date}.bak'.format( + path=profiles_ini_path, **global_vars) + backup_path = non_clobber_rename(backup_path) + shutil.move(profiles_ini_path, backup_path) + run_program([exe_path, '-createprofile', 'default'], check=False) + profiles.extend( + get_mozilla_profiles( + search_path=browser['user_data_path'], dev=dev)) + + elif 'Opera' in name: + if os.path.exists(browser['user_data_path']): + profiles.append( + {'name': 'Default', 'path': browser['user_data_path']}) + + # Skip browser if there's no profiles + if len(profiles) == 0: + raise NoProfilesError + + # Get homepages + if browser['base'] == 'ie': + # IE is set to only have one profile above + profiles[0]['homepages'] = get_ie_homepages() + elif browser['base'] == 'mozilla': + for profile in profiles: + prefs_path = r'{path}\prefs.js'.format(**profile) + profile['homepages'] = get_mozilla_homepages(prefs_path=prefs_path) + + # Add to browser_data + browser_data[name] = browser + browser_data[name].update({ + 'exe_path': exe_path, + 'profiles': profiles, + }) + + # Raise installation warnings (if any) + if num_installs == 0: + raise NotInstalledError + elif num_installs > 1 and browser['base'] != 'ie': + raise MultipleInstallationsError + +def get_chromium_profiles(search_path): + """Find any chromium-style profiles and return as a list of dicts.""" + profiles = [] + try: + for entry in os.scandir(search_path): + if entry.is_dir() and REGEX_CHROMIUM_PROFILE.search(entry.name): + profiles.append(entry) + REGEX_PROFILE_BACKUP = r'\.\w+bak.*' + profiles = [p for p in profiles if not REGEX_BACKUP.search(p.name)] + # Convert os.DirEntries to dicts + profiles = [{'name': p.name, 'path': p.path} for p in profiles] + except Exception: + pass + + return profiles + +def get_ie_homepages(): + """Read homepages from the registry and return as a list.""" + homepages = [] + main_page = '' + extra_pages = [] + key = r'Software\Microsoft\Internet Explorer\Main' + with winreg.OpenKey(HKCU, key) as _key: + try: + main_page = winreg.QueryValueEx(_key, 'Start Page')[0] + except FileNotFoundError: + pass + try: + extra_pages = winreg.QueryValueEx(_key, 'Secondary Start Pages')[0] + except FileNotFoundError: + pass + if main_page != '': + homepages.append(main_page) + if len(extra_pages) > 0: + homepages.extend(extra_pages) + return homepages + +def get_mozilla_homepages(prefs_path): + """Read homepages from prefs.js and return as a list.""" + homepages = [] + try: + with open(prefs_path, 'r') as f: + search = re.search( + r'browser\.startup\.homepage", "([^"]*)"', + f.read(), re.IGNORECASE) + if search: + homepages = search.group(1).split('|') + except Exception: + pass + + return homepages + +def get_mozilla_profiles(search_path, dev=False): + """Find any mozilla-style profiles and return as a list of dicts.""" + profiles = [] + try: + for entry in os.scandir(search_path): + if entry.is_dir(): + if 'dev-edition' in entry.name: + # NOTE: Not always present which can lead + # to Dev profiles being marked as non-Dev + ## NOTE 2: It is possible that a non-Dev profile + ## to be created with 'dev-edition' in the name. + ## (It wouldn't make sense, but possible) + if dev: + profiles.append(entry) + elif not dev: + profiles.append(entry) + profiles = [p for p in profiles if not REGEX_BACKUP.search(p.name)] + # Convert os.DirEntries to dicts + profiles = [{'name': p.name, 'path': p.path} for p in profiles] + except Exception: + pass + + return profiles + +def install_adblock(indent=8, width=32): + """Install adblock for all supported browsers.""" + for browser in sorted(browser_data): + exe_path = browser_data[browser].get('exe_path', None) + function=run_program + if exe_path is None: + print_standard( + '{indent}{browser:<{width}}'.format( + indent=' '*indent, width=width, browser=browser+'...'), + end='', flush=True) + print_warning('Not installed', timestamp=False) + else: + # Set urls to open + urls = [] + if browser_data[browser]['base'] == 'chromium': + if browser == 'Google Chrome': + # Check for system exensions + try: + winreg.QueryValue(HKLM, UBO_CHROME_REG) + except FileNotFoundError: + urls.append(UBO_CHROME) + try: + winreg.QueryValue(HKLM, UBO_EXTRA_CHROME_REG) + except FileNotFoundError: + urls.append(UBO_EXTRA_CHROME) + + if len(urls) == 0: + urls = ['chrome://extensions'] + elif 'Opera' in browser: + urls.append(UBO_OPERA) + else: + urls.append(UBO_CHROME) + urls.append(UBO_EXTRA_CHROME) + + elif browser_data[browser]['base'] == 'mozilla': + # Assume UBO is not installed first and change if it is + urls.append(UBO_MOZILLA) + if browser == 'Mozilla Firefox': + ubo = browser_data[browser]['exe_path'].replace( + 'firefox.exe', + r'distribution\extensions\uBlock0@raymondhill.net') + if os.path.exists(ubo): + urls = ['about:addons'] + + elif browser_data[browser]['base'] == 'ie': + urls.append(IE_GALLERY) + function=popen_program + + # By using check=False we're skipping any return codes so + # it should only fail if the program can't be run + # (or can't be found). + # In other words, this isn't tracking the addon/extension's + # installation status. + try_and_print(message='{}...'.format(browser), + indent=indent, width=width, + cs='Done', function=function, + cmd=[exe_path, *urls], check=False) + +def list_homepages(indent=8, width=32): + """List current homepages for reference.""" + + for browser in sorted(browser_data): + # Skip Chromium-based browsers + if browser_data[browser]['base'] == 'chromium': + print_info( + '{indent}{browser:<{width}}'.format( + indent=' '*indent, width=width, browser=browser+'...'), + end='', flush=True) + print_warning('Not implemented', timestamp=False) + continue + + # All other browsers + profiles = browser_data[browser].get('profiles', []) + if profiles: + print_info('{indent}{browser:<{width}}'.format( + indent=' '*indent, width=width, browser=browser+'...')) + for profile in profiles: + _name = profile.get('name', '?') + _homepages = profile.get('homepages', []) + if len(_homepages) == 0: + print_standard( + '{indent}{name:<{width}}'.format( + indent=' '*indent, width=width, name=_name), + end='', flush=True) + print_warning('None found', timestamp=False) + else: + for page in _homepages: + print_standard('{indent}{name:<{width}}{page}'.format( + indent=' '*indent, width=width, name=_name, page=page)) + +def reset_browsers(indent=8, width=32): + """Reset all detected browsers to safe defaults.""" + for browser in sorted(browser_data): + print_info('{indent}{name}'.format(indent=' '*indent, name=browser)) + for profile in browser_data[browser]['profiles']: + if browser_data[browser]['base'] == 'chromium': + function = clean_chromium_profile + elif browser_data[browser]['base'] == 'ie': + function = clean_internet_explorer + elif browser_data[browser]['base'] == 'mozilla': + function = clean_mozilla_profile + try_and_print( + message='{}...'.format(profile['name']), + indent=indent, width=width, function=function, + other_results=other_results, profile=profile) + +def scan_for_browsers(): + """Scan system for any supported browsers.""" + for name in sorted(SUPPORTED_BROWSERS): + try_and_print(message='{}...'.format(name), + function=get_browser_details, cs='Detected', + other_results=other_results, name=name) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/cleanup.py b/.bin/Scripts/functions/cleanup.py index 1bac4c6c..c5562961 100644 --- a/.bin/Scripts/functions/cleanup.py +++ b/.bin/Scripts/functions/cleanup.py @@ -1,91 +1,91 @@ -# Wizard Kit: Functions - Cleanup - -from functions.common import * - -def cleanup_adwcleaner(): - """Move AdwCleaner folders into the ClientDir.""" - source_path = r'{SYSTEMDRIVE}\AdwCleaner'.format(**global_vars['Env']) - source_quarantine = r'{}\Quarantine'.format(source_path) - - # Quarantine - if os.path.exists(source_quarantine): - os.makedirs(global_vars['QuarantineDir'], exist_ok=True) - dest_name = r'{QuarantineDir}\AdwCleaner_{Date-Time}'.format( - **global_vars) - dest_name = non_clobber_rename(dest_name) - shutil.move(source_quarantine, dest_name) - - # Delete source folder if empty - try: - os.rmdir(source_path) - except OSError: - pass - - # Main folder - if os.path.exists(source_path): - os.makedirs(global_vars['ProgBackupDir'], exist_ok=True) - dest_name = r'{ProgBackupDir}\AdwCleaner_{Date-Time}'.format( - **global_vars) - dest_name = non_clobber_rename(dest_name) - shutil.move(source_path, dest_name) - -def cleanup_cbs(dest_folder): - """Safely cleanup a known CBS archive bug under Windows 7. - - If a CbsPersist file is larger than 2 Gb then the auto archive feature - continually fails and will fill up the system drive with temp files. - - This function moves the temp files and CbsPersist file to a temp folder, - compresses the CbsPersist files with 7-Zip, and then opens the temp folder - for the user to manually save the backup files and delete the temp files. - """ - backup_folder = r'{dest_folder}\CbsFix'.format(dest_folder=dest_folder) - temp_folder = r'{backup_folder}\Temp'.format(backup_folder=backup_folder) - os.makedirs(backup_folder, exist_ok=True) - os.makedirs(temp_folder, exist_ok=True) - - # Move files into temp folder - cbs_path = r'{SYSTEMROOT}\Logs\CBS'.format(**global_vars['Env']) - for entry in os.scandir(cbs_path): - # CbsPersist files - if entry.name.lower().startswith('cbspersist'): - dest_name = r'{}\{}'.format(temp_folder, entry.name) - dest_name = non_clobber_rename(dest_name) - shutil.move(entry.path, dest_name) - temp_path = r'{SYSTEMROOT}\Temp'.format(**global_vars['Env']) - for entry in os.scandir(temp_path): - # cab_ files - if entry.name.lower().startswith('cab_'): - dest_name = r'{}\{}'.format(temp_folder, entry.name) - dest_name = non_clobber_rename(dest_name) - shutil.move(entry.path, dest_name) - - # Compress CbsPersist files with 7-Zip - cmd = [ - global_vars['Tools']['SevenZip'], - 'a', '-t7z', '-mx=3', '-bso0', '-bse0', - r'{}\CbsPersists.7z'.format(backup_folder), - r'{}\CbsPersist*'.format(temp_folder)] - run_program(cmd) - -def cleanup_desktop(): - """Move known backup files and reports into the ClientDir.""" - dest_folder = r'{ProgBackupDir}\Desktop_{Date-Time}'.format(**global_vars) - os.makedirs(dest_folder, exist_ok=True) - - desktop_path = r'{USERPROFILE}\Desktop'.format(**global_vars['Env']) - for entry in os.scandir(desktop_path): - # JRT, RKill, Shortcut cleaner - if re.search(r'^(JRT|RKill|sc-cleaner)', entry.name, re.IGNORECASE): - dest_name = r'{}\{}'.format(dest_folder, entry.name) - dest_name = non_clobber_rename(dest_name) - shutil.move(entry.path, dest_name) - - # Remove dir if empty - try: - os.rmdir(dest_folder) - except OSError: - pass - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Cleanup + +from functions.common import * + +def cleanup_adwcleaner(): + """Move AdwCleaner folders into the ClientDir.""" + source_path = r'{SYSTEMDRIVE}\AdwCleaner'.format(**global_vars['Env']) + source_quarantine = r'{}\Quarantine'.format(source_path) + + # Quarantine + if os.path.exists(source_quarantine): + os.makedirs(global_vars['QuarantineDir'], exist_ok=True) + dest_name = r'{QuarantineDir}\AdwCleaner_{Date-Time}'.format( + **global_vars) + dest_name = non_clobber_rename(dest_name) + shutil.move(source_quarantine, dest_name) + + # Delete source folder if empty + try: + os.rmdir(source_path) + except OSError: + pass + + # Main folder + if os.path.exists(source_path): + os.makedirs(global_vars['ProgBackupDir'], exist_ok=True) + dest_name = r'{ProgBackupDir}\AdwCleaner_{Date-Time}'.format( + **global_vars) + dest_name = non_clobber_rename(dest_name) + shutil.move(source_path, dest_name) + +def cleanup_cbs(dest_folder): + """Safely cleanup a known CBS archive bug under Windows 7. + + If a CbsPersist file is larger than 2 Gb then the auto archive feature + continually fails and will fill up the system drive with temp files. + + This function moves the temp files and CbsPersist file to a temp folder, + compresses the CbsPersist files with 7-Zip, and then opens the temp folder + for the user to manually save the backup files and delete the temp files. + """ + backup_folder = r'{dest_folder}\CbsFix'.format(dest_folder=dest_folder) + temp_folder = r'{backup_folder}\Temp'.format(backup_folder=backup_folder) + os.makedirs(backup_folder, exist_ok=True) + os.makedirs(temp_folder, exist_ok=True) + + # Move files into temp folder + cbs_path = r'{SYSTEMROOT}\Logs\CBS'.format(**global_vars['Env']) + for entry in os.scandir(cbs_path): + # CbsPersist files + if entry.name.lower().startswith('cbspersist'): + dest_name = r'{}\{}'.format(temp_folder, entry.name) + dest_name = non_clobber_rename(dest_name) + shutil.move(entry.path, dest_name) + temp_path = r'{SYSTEMROOT}\Temp'.format(**global_vars['Env']) + for entry in os.scandir(temp_path): + # cab_ files + if entry.name.lower().startswith('cab_'): + dest_name = r'{}\{}'.format(temp_folder, entry.name) + dest_name = non_clobber_rename(dest_name) + shutil.move(entry.path, dest_name) + + # Compress CbsPersist files with 7-Zip + cmd = [ + global_vars['Tools']['SevenZip'], + 'a', '-t7z', '-mx=3', '-bso0', '-bse0', + r'{}\CbsPersists.7z'.format(backup_folder), + r'{}\CbsPersist*'.format(temp_folder)] + run_program(cmd) + +def cleanup_desktop(): + """Move known backup files and reports into the ClientDir.""" + dest_folder = r'{ProgBackupDir}\Desktop_{Date-Time}'.format(**global_vars) + os.makedirs(dest_folder, exist_ok=True) + + desktop_path = r'{USERPROFILE}\Desktop'.format(**global_vars['Env']) + for entry in os.scandir(desktop_path): + # JRT, RKill, Shortcut cleaner + if re.search(r'^(JRT|RKill|sc-cleaner)', entry.name, re.IGNORECASE): + dest_name = r'{}\{}'.format(dest_folder, entry.name) + dest_name = non_clobber_rename(dest_name) + shutil.move(entry.path, dest_name) + + # Remove dir if empty + try: + os.rmdir(dest_folder) + except OSError: + pass + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/common.py b/.bin/Scripts/functions/common.py index b1002f12..4697cfa7 100644 --- a/.bin/Scripts/functions/common.py +++ b/.bin/Scripts/functions/common.py @@ -1,685 +1,685 @@ -# Wizard Kit: Functions - Common - -import os -import psutil -import re -import shutil -import subprocess -import sys -import time -import traceback -import winreg - -from subprocess import CalledProcessError - -from settings.main import * -from settings.tools import * - -# Global variables -global_vars = {} - -# STATIC VARIABLES -COLORS = { - 'CLEAR': '\033[0m', - 'RED': '\033[31m', - 'GREEN': '\033[32m', - 'YELLOW': '\033[33m', - 'BLUE': '\033[34m' -} -HKU = winreg.HKEY_USERS -HKCU = winreg.HKEY_CURRENT_USER -HKLM = winreg.HKEY_LOCAL_MACHINE - -# Error Classes -class BIOSKeyNotFoundError(Exception): - pass - -class BinNotFoundError(Exception): - pass - -class GenericError(Exception): - pass - -class GenericRepair(Exception): - pass - -class MultipleInstallationsError(Exception): - pass - -class NotInstalledError(Exception): - pass - -class NoProfilesError(Exception): - pass - -class PathNotFoundException(Exception): - pass - -class UnsupportedOSError(Exception): - pass - -# General functions -def abort(): - """Abort script.""" - print_warning('Aborted.') - sleep(5) - exit_script() - -def ask(prompt='Kotaero!'): - """Prompt the user with a Y/N question, log answer, and return a bool.""" - answer = None - prompt = '{} [Y/N]: '.format(prompt) - while answer is None: - tmp = input(prompt) - if re.search(r'^y(es|)$', tmp, re.IGNORECASE): - answer = True - elif re.search(r'^n(o|ope|)$', tmp, re.IGNORECASE): - answer = False - message = '{prompt}{answer_text}'.format( - prompt = prompt, - answer_text = 'Yes' if answer else 'No') - print_log(message=message) - return answer - -def convert_to_bytes(size): - """Convert human-readable size str to bytes and return an int.""" - size = str(size) - tmp = re.search(r'(\d+)\s+([KMGT]B)', size.upper()) - if tmp: - size = int(tmp.group(1)) - units = tmp.group(2) - if units == 'TB': - size *= 1099511627776 - elif units == 'GB': - size *= 1073741824 - elif units == 'MB': - size *= 1048576 - elif units == 'KB': - size *= 1024 - else: - return -1 - - return size - -def exit_script(return_value=0): - """Exits the script after some cleanup and opens the log (if set).""" - # Remove dirs (if empty) - for dir in ['BackupDir', 'LogDir', 'TmpDir']: - try: - dir = global_vars[dir] - os.rmdir(dir) - except Exception: - pass - - # Open Log (if it exists) - log = global_vars.get('LogFile', '') - if log and os.path.exists(log): - try: - extract_item('NotepadPlusPlus', silent=True) - popen_program( - [global_vars['Tools']['NotepadPlusPlus'], - global_vars['LogFile']]) - except Exception: - print_error('ERROR: Failed to extract Notepad++ and open log.') - pause('Press Enter to exit...') - - # Kill Caffeine if still running - kill_process('caffeine.exe') - - # Exit - sys.exit(return_value) - -def extract_item(item, filter='', silent=False): - """Extract item from .cbin into .bin.""" - cmd = [ - global_vars['Tools']['SevenZip'], 'x', '-aos', '-bso0', '-bse0', - '-p{ArchivePassword}'.format(**global_vars), - r'-o{BinDir}\{item}'.format(item=item, **global_vars), - r'{CBinDir}\{item}.7z'.format(item=item, **global_vars), - filter] - if not silent: - print_standard('Extracting "{item}"...'.format(item=item)) - try: - run_program(cmd) - except subprocess.CalledProcessError: - if not silent: - print_warning('WARNING: Errors encountered while exctracting data') - -def get_ticket_number(): - """Get TicketNumber from user, save in LogDir, and return as str.""" - ticket_number = None - while ticket_number is None: - _input = input('Enter ticket number: ') - if re.match(r'^([0-9]+([-_]?\w+|))$', _input): - ticket_number = _input - with open(r'{LogDir}\TicketNumber'.format(**global_vars), 'w') as f: - f.write(ticket_number) - return ticket_number - -def human_readable_size(size, decimals=0): - """Convert size in bytes to a human-readable format and return a str.""" - # Prep string formatting - width = 3+decimals - if decimals > 0: - width += 1 - - # Convert size to int - try: - size = int(size) - except ValueError: - size = convert_to_bytes(size) - - # Verify we have a valid size - if size <= 0: - return '{size:>{width}} b'.format(size='???', width=width) - - # Convert to sensible units - if size >= 1099511627776: - size /= 1099511627776 - units = 'Tb' - elif size >= 1073741824: - size /= 1073741824 - units = 'Gb' - elif size >= 1048576: - size /= 1048576 - units = 'Mb' - elif size >= 1024: - size /= 1024 - units = 'Kb' - else: - units = ' b' - - # Return - return '{size:>{width}.{decimals}f} {units}'.format( - size=size, width=width, decimals=decimals, units=units) - -def kill_process(name): - """Kill any running caffeine.exe processes.""" - for proc in psutil.process_iter(): - if proc.name() == name: - proc.kill() - -def major_exception(): - """Display traceback and exit""" - print_error('Major exception') - print_warning( - " Please let {tech} know and they'll look into it" - " (include the details below).".format(tech=SUPPORT_TECH)) - print(traceback.format_exc()) - print_log(traceback.format_exc()) - sleep(30) - pause('Press Enter to exit...') - # sys.exit(1) - exit_script(1) - -def menu_select(title='~ Untitled Menu ~', - prompt='Please make a selection', secret_exit=False, - main_entries=[], action_entries=[], disabled_label='DISABLED'): - """Display options in a menu and return selected option as a str.""" - # Bail early - if not main_entries and not action_entries: - raise Exception("MenuError: No items given") - - # Build menu - menu_splash = '{}\n\n'.format(title) - width = len(str(len(main_entries))) - valid_answers = [] - if (secret_exit): - valid_answers.append('Q') - - # Add main entries - for i in range(len(main_entries)): - entry = main_entries[i] - # Add Spacer - if ('CRLF' in entry): - menu_splash += '\n' - entry_str = '{number:>{width}}: {name}'.format( - number = i+1, - width = width, - name = entry.get('Display Name', entry['Name'])) - if entry.get('Disabled', False): - entry_str = '{YELLOW}{entry_str} ({disabled}){CLEAR}'.format( - entry_str = entry_str, - disabled = disabled_label, - **COLORS) - else: - valid_answers.append(str(i+1)) - menu_splash += '{}\n'.format(entry_str) - menu_splash += '\n' - - # Add action entries - for entry in action_entries: - # Add Spacer - if ('CRLF' in entry): - menu_splash += '\n' - valid_answers.append(entry['Letter']) - menu_splash += '{letter:>{width}}: {name}\n'.format( - letter = entry['Letter'].upper(), - width = len(str(len(action_entries))), - name = entry['Name']) - menu_splash += '\n' - - answer = '' - - while (answer.upper() not in valid_answers): - os.system('cls') - print(menu_splash) - answer = input('{}: '.format(prompt)) - - return answer.upper() - -def non_clobber_rename(full_path): - """Append suffix to path, if necessary, to avoid clobbering path""" - new_path = full_path - _i = 1; - while os.path.exists(new_path): - new_path = '{path}_{i}'.format(i=_i, path=full_path) - _i += 1 - - return new_path - -def pause(prompt='Press Enter to continue... '): - """Simple pause implementation.""" - input(prompt) - -def ping(addr='google.com'): - """Attempt to ping addr.""" - cmd = ['ping', '-n', '2', addr] - run_program(cmd) - -def popen_program(cmd, pipe=False, minimized=False, shell=False, **kwargs): - """Run program and return a subprocess.Popen object.""" - startupinfo=None - if minimized: - startupinfo = subprocess.STARTUPINFO() - startupinfo.dwFlags = subprocess.STARTF_USESHOWWINDOW - startupinfo.wShowWindow = 6 - - if pipe: - popen_obj = subprocess.Popen(cmd, shell=shell, startupinfo=startupinfo, - stdout=subprocess.PIPE, stderr=subprocess.PIPE) - else: - popen_obj = subprocess.Popen(cmd, shell=shell, startupinfo=startupinfo) - - return popen_obj - -def print_error(*args, **kwargs): - """Prints message to screen in RED.""" - print_standard(*args, color=COLORS['RED'], **kwargs) - -def print_info(*args, **kwargs): - """Prints message to screen in BLUE.""" - print_standard(*args, color=COLORS['BLUE'], **kwargs) - -def print_warning(*args, **kwargs): - """Prints message to screen in YELLOW.""" - print_standard(*args, color=COLORS['YELLOW'], **kwargs) - -def print_standard(message='Generic info', - color=None, end='\n', timestamp=True, **kwargs): - """Prints message to screen and log (if set).""" - display_message = message - if color: - display_message = color + message + COLORS['CLEAR'] - # **COLORS is used below to support non-"standard" color printing - print(display_message.format(**COLORS), end=end, **kwargs) - print_log(message, end, timestamp) - -def print_success(*args, **kwargs): - """Prints message to screen in GREEN.""" - print_standard(*args, color=COLORS['GREEN'], **kwargs) - -def print_log(message='', end='\n', timestamp=True): - time_str = time.strftime("%Y-%m-%d %H%M%z: ") if timestamp else '' - if 'LogFile' in global_vars and global_vars['LogFile'] is not None: - with open(global_vars['LogFile'], 'a') as f: - for line in message.splitlines(): - f.write('{timestamp}{line}{end}'.format( - timestamp = time_str, - line = line, - end = end)) - -def run_program(cmd, args=[], check=True, pipe=True, shell=False): - """Run program and return a subprocess.CompletedProcess object.""" - if args: - # Deprecated so let's raise an exception to find & fix all occurances - print_error('ERROR: Using args is no longer supported.') - raise Exception - cmd = [c for c in cmd if c] - if shell: - cmd = ' '.join(cmd) - - if pipe: - process_return = subprocess.run(cmd, check=check, shell=shell, - stdout=subprocess.PIPE, stderr=subprocess.PIPE) - else: - process_return = subprocess.run(cmd, check=check, shell=shell) - - return process_return - -def show_info(message='~Some message~', info='~Some info~', indent=8, width=32): - """Display info with formatting.""" - print_standard('{indent}{message:<{width}}{info}'.format( - indent=' '*indent, width=width, message=message, info=info)) - -def sleep(seconds=2): - """Wait for a while.""" - time.sleep(seconds) - -def stay_awake(): - """Prevent the system from sleeping or hibernating.""" - # Bail if caffeine is already running - for proc in psutil.process_iter(): - if proc.name() == 'caffeine.exe': - return - # Extract and run - extract_item('Caffeine', silent=True) - try: - popen_program(global_vars['Tools']['Caffeine']) - except Exception: - print_error('ERROR: No caffeine available.') - print_warning('Please set the power setting to High Performance.') - -def get_exception(s): - """Get exception by name, returns Exception object.""" - return getattr(sys.modules[__name__], s) - -def try_and_print(message='Trying...', - function=None, cs='CS', ns='NS', other_results={}, - catch_all=True, print_return=False, silent_function=True, - indent=8, width=32, *args, **kwargs): - """Run function, print if successful or not, and return dict. - - other_results is in the form of - { - 'Warning': {'ExceptionClassName': 'Result Message'}, - 'Error': {'ExceptionClassName': 'Result Message'} - } - The the ExceptionClassNames will be excepted conditions - and the result string will be printed in the correct color. - catch_all=False will result in unspecified exceptions being re-raised.""" - err = None - w_exceptions = other_results.get('Warning', {}).keys() - w_exceptions = tuple(get_exception(e) for e in w_exceptions) - e_exceptions = other_results.get('Error', {}).keys() - e_exceptions = tuple(get_exception(e) for e in e_exceptions) - w_results = other_results.get('Warning', {}) - e_results = other_results.get('Error', {}) - - # Run function and catch errors - print_standard('{indent}{message:<{width}}'.format( - indent=' '*indent, message=message, width=width), end='', flush=True) - try: - out = function(*args, **kwargs) - if print_return: - print_standard(out[0], timestamp=False) - for item in out[1:]: - print_standard('{indent}{item}'.format( - indent=' '*(indent+width), item=item)) - elif silent_function: - print_success(cs, timestamp=False) - except w_exceptions as e: - _result = w_results.get(e.__class__.__name__, 'Warning') - print_warning(_result, timestamp=False) - err = e - except e_exceptions as e: - _result = e_results.get(e.__class__.__name__, 'Error') - print_error(_result, timestamp=False) - err = e - except Exception: - print_error(ns, timestamp=False) - err = traceback.format_exc() - - # Return or raise? - if bool(err) and not catch_all: - raise - else: - return {'CS': not bool(err), 'Error': err} - -def upload_data(path, file): - """Add CLIENT_INFO_SERVER to authorized connections and upload file.""" - if not ENABLED_UPLOAD_DATA: - raise GenericError('Feature disabled.') - - extract_item('PuTTY', filter='wizkit.ppk psftp.exe', silent=True) - - # Authorize connection to the server - winreg.CreateKey(HKCU, r'Software\SimonTatham\PuTTY\SshHostKeys') - with winreg.OpenKey(HKCU, r'Software\SimonTatham\PuTTY\SshHostKeys', - access=winreg.KEY_WRITE) as key: - winreg.SetValueEx(key, - 'rsa2@22:{IP}'.format(**CLIENT_INFO_SERVER), 0, - winreg.REG_SZ, CLIENT_INFO_SERVER['RegEntry']) - - # Write batch file - with open(r'{TmpDir}\psftp.batch'.format(**global_vars), - 'w', encoding='ascii') as f: - f.write('lcd "{path}"\n'.format(path=path)) - f.write('cd "{Share}"\n'.format(**CLIENT_INFO_SERVER)) - f.write('mkdir {TicketNumber}\n'.format(**global_vars)) - f.write('cd {TicketNumber}\n'.format(**global_vars)) - f.write('put "{file}"\n'.format(file=file)) - - # Upload Info - cmd = [ - global_vars['Tools']['PuTTY-PSFTP'], - '-noagent', - '-i', r'{BinDir}\PuTTY\wizkit.ppk'.format(**global_vars), - '{User}@{IP}'.format(**CLIENT_INFO_SERVER), - '-b', r'{TmpDir}\psftp.batch'.format(**global_vars)] - run_program(cmd) - -def upload_info(): - """Upload compressed Info file to the NAS as set in settings.main.py.""" - if not ENABLED_UPLOAD_DATA: - raise GenericError('Feature disabled.') - - path = '{ClientDir}'.format(**global_vars) - file = 'Info_{Date-Time}.7z'.format(**global_vars) - upload_data(path, file) - -def compress_info(): - """Compress ClientDir info folders with 7-Zip for upload_info().""" - path = '{ClientDir}'.format(**global_vars) - file = 'Info_{Date-Time}.7z'.format(**global_vars) - _cmd = [ - global_vars['Tools']['SevenZip'], - 'a', '-t7z', '-mx=9', '-bso0', '-bse0', - r'{}\{}'.format(path, file), - r'{ClientDir}\Info'.format(**global_vars)] - run_program(_cmd) - -def wait_for_process(name, poll_rate=3): - """Wait for process by name.""" - running = True - while running: - sleep(poll_rate) - running = False - for proc in psutil.process_iter(): - if re.search(r'^{}'.format(name), proc.name(), re.IGNORECASE): - running = True - sleep(1) - -# global_vars functions -def init_global_vars(): - """Sets global variables based on system info.""" - print_info('Initializing') - os.system('title Wizard Kit') - init_functions = [ - ['Checking .bin...', find_bin], - ['Checking environment...', set_common_vars], - ['Checking OS...', check_os], - ['Checking tools...', check_tools], - ['Creating folders...', make_tmp_dirs], - ['Clearing collisions...', clean_env_vars], - ] - try: - for f in init_functions: - try_and_print( - message=f[0], function=f[1], - cs='Done', ns='Error', catch_all=False) - except: - major_exception() - -def check_os(): - """Set OS specific variables.""" - tmp = {} - - # Query registry - _reg_path = winreg.OpenKey( - HKLM, r'SOFTWARE\Microsoft\Windows NT\CurrentVersion') - for key in ['CSDVersion', 'CurrentBuild', 'CurrentBuildNumber', - 'CurrentVersion', 'ProductName']: - try: - tmp[key] = winreg.QueryValueEx(_reg_path, key)[0] - if key in ['CurrentBuild', 'CurrentBuildNumber']: - tmp[key] = int(tmp[key]) - except ValueError: - # Couldn't convert Build to int so this should be interesting... - tmp[key] = 0 - except Exception: - tmp[key] = 'Unknown' - - # Determine OS bit depth - tmp['Arch'] = 32 - if 'PROGRAMFILES(X86)' in global_vars['Env']: - tmp['Arch'] = 64 - - # Determine OS Name - tmp['Name'] = '{ProductName} {CSDVersion}'.format(**tmp) - if tmp['CurrentBuild'] == 9600: - tmp['Name'] += ' Update' # Win 8.1u - if tmp['CurrentBuild'] == 10240: - tmp['Name'] += ' Release 1507 "Threshold 1"' - if tmp['CurrentBuild'] == 10586: - tmp['Name'] += ' Release 1511 "Threshold 2"' - if tmp['CurrentBuild'] == 14393: - tmp['Name'] += ' Release 1607 "Redstone 1" / "Anniversary Update"' - if tmp['CurrentBuild'] == 15063: - tmp['Name'] += ' Release 1703 "Redstone 2" / "Creators Update"' - if tmp['CurrentBuild'] == 16299: - tmp['Name'] += ' Release 1709 "Redstone 3" / "Fall Creators Update"' - tmp['Name'] = tmp['Name'].replace('Service Pack ', 'SP') - tmp['Name'] = tmp['Name'].replace('Unknown Release', 'Release') - tmp['Name'] = re.sub(r'\s+', ' ', tmp['Name']) - - # Determine OS version - name = '{Name} x{Arch}'.format(**tmp) - if tmp['CurrentVersion'] == '6.0': - tmp['Version'] = 'Vista' - name += ' (very outdated)' - elif tmp['CurrentVersion'] == '6.1': - tmp['Version'] = '7' - if tmp['CSDVersion'] == 'Service Pack 1': - name += ' (outdated)' - else: - name += ' (very outdated)' - elif tmp['CurrentVersion'] in ['6.2', '6.3']: - if int(tmp['CurrentBuildNumber']) <= 9600: - tmp['Version'] = '8' - elif int(tmp['CurrentBuildNumber']) >= 10240: - tmp['Version'] = '10' - if tmp['CurrentBuild'] in [9200, 10240, 10586]: - name += ' (very outdated)' - elif tmp['CurrentBuild'] in [9600, 14393, 15063]: - name += ' (outdated)' - elif tmp['CurrentBuild'] == 16299: - pass # Current Win10 - else: - name += ' (unrecognized)' - tmp['DisplayName'] = name - - # == vista == - # 6.0.6000 - # 6.0.6001 - # 6.0.6002 - # ==== 7 ==== - # 6.1.7600 - # 6.1.7601 - # 6.1.7602 - # ==== 8 ==== - # 6.2.9200 - # === 8.1 === - # 6.3.9200 - # === 8.1u == - # 6.3.9600 - # === 10 v1507 "Threshold 1" == - # 6.3.10240 - # === 10 v1511 "Threshold 2" == - # 6.3.10586 - # === 10 v1607 "Redstone 1" "Anniversary Update" == - # 6.3.14393 - # === 10 v1703 "Redstone 2" "Creators Update" == - # 6.3.15063 - # === 10 v1709 "Redstone 3" "Fall Creators Update" == - # 6.3.16299 - global_vars['OS'] = tmp - -def check_tools(): - """Set tool variables based on OS bit-depth and tool availability.""" - if global_vars['OS'].get('Arch', 32) == 64: - global_vars['Tools'] = {k: v.get('64', v.get('32')) - for (k, v) in TOOLS.items()} - else: - global_vars['Tools'] = {k: v.get('32') for (k, v) in TOOLS.items()} - - # Fix paths - global_vars['Tools'] = {k: os.path.join(global_vars['BinDir'], v) - for (k, v) in global_vars['Tools'].items()} - -def clean_env_vars(): - """Remove conflicting global_vars and env variables. - - This fixes an issue where both global_vars and - global_vars['Env'] are expanded at the same time.""" - for key in global_vars.keys(): - global_vars['Env'].pop(key, None) - -def find_bin(): - """Find .bin folder in the cwd or it's parents.""" - wd = os.getcwd() - base = None - while base is None: - if os.path.exists('.bin'): - base = os.getcwd() - break - if re.fullmatch(r'\w:\\', os.getcwd()): - break - os.chdir('..') - os.chdir(wd) - if base is None: - raise BinNotFoundError - global_vars['BaseDir'] = base - -def make_tmp_dirs(): - """Make temp directories.""" - os.makedirs(global_vars['BackupDir'], exist_ok=True) - os.makedirs(global_vars['LogDir'], exist_ok=True) - os.makedirs(global_vars['TmpDir'], exist_ok=True) - -def set_common_vars(): - """Set common variables.""" - global_vars['Date'] = time.strftime("%Y-%m-%d") - global_vars['Date-Time'] = time.strftime("%Y-%m-%d_%H%M_%z") - global_vars['Env'] = os.environ.copy() - - global_vars['ArchivePassword'] = ARCHIVE_PASSWORD - global_vars['BinDir'] = r'{BaseDir}\.bin'.format( - **global_vars) - global_vars['CBinDir'] = r'{BaseDir}\.cbin'.format( - **global_vars) - global_vars['ClientDir'] = r'{SYSTEMDRIVE}\{prefix}'.format( - prefix=KIT_NAME_SHORT, **global_vars['Env']) - global_vars['BackupDir'] = r'{ClientDir}\Backups\{Date}'.format( - **global_vars) - global_vars['LogDir'] = r'{ClientDir}\Info\{Date}'.format( - **global_vars) - global_vars['ProgBackupDir'] = r'{ClientDir}\Backups'.format( - **global_vars) - global_vars['QuarantineDir'] = r'{ClientDir}\Quarantine'.format( - **global_vars) - global_vars['TmpDir'] = r'{BinDir}\tmp'.format( - **global_vars) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Common + +import os +import psutil +import re +import shutil +import subprocess +import sys +import time +import traceback +import winreg + +from subprocess import CalledProcessError + +from settings.main import * +from settings.tools import * + +# Global variables +global_vars = {} + +# STATIC VARIABLES +COLORS = { + 'CLEAR': '\033[0m', + 'RED': '\033[31m', + 'GREEN': '\033[32m', + 'YELLOW': '\033[33m', + 'BLUE': '\033[34m' +} +HKU = winreg.HKEY_USERS +HKCU = winreg.HKEY_CURRENT_USER +HKLM = winreg.HKEY_LOCAL_MACHINE + +# Error Classes +class BIOSKeyNotFoundError(Exception): + pass + +class BinNotFoundError(Exception): + pass + +class GenericError(Exception): + pass + +class GenericRepair(Exception): + pass + +class MultipleInstallationsError(Exception): + pass + +class NotInstalledError(Exception): + pass + +class NoProfilesError(Exception): + pass + +class PathNotFoundException(Exception): + pass + +class UnsupportedOSError(Exception): + pass + +# General functions +def abort(): + """Abort script.""" + print_warning('Aborted.') + sleep(5) + exit_script() + +def ask(prompt='Kotaero!'): + """Prompt the user with a Y/N question, log answer, and return a bool.""" + answer = None + prompt = '{} [Y/N]: '.format(prompt) + while answer is None: + tmp = input(prompt) + if re.search(r'^y(es|)$', tmp, re.IGNORECASE): + answer = True + elif re.search(r'^n(o|ope|)$', tmp, re.IGNORECASE): + answer = False + message = '{prompt}{answer_text}'.format( + prompt = prompt, + answer_text = 'Yes' if answer else 'No') + print_log(message=message) + return answer + +def convert_to_bytes(size): + """Convert human-readable size str to bytes and return an int.""" + size = str(size) + tmp = re.search(r'(\d+)\s+([KMGT]B)', size.upper()) + if tmp: + size = int(tmp.group(1)) + units = tmp.group(2) + if units == 'TB': + size *= 1099511627776 + elif units == 'GB': + size *= 1073741824 + elif units == 'MB': + size *= 1048576 + elif units == 'KB': + size *= 1024 + else: + return -1 + + return size + +def exit_script(return_value=0): + """Exits the script after some cleanup and opens the log (if set).""" + # Remove dirs (if empty) + for dir in ['BackupDir', 'LogDir', 'TmpDir']: + try: + dir = global_vars[dir] + os.rmdir(dir) + except Exception: + pass + + # Open Log (if it exists) + log = global_vars.get('LogFile', '') + if log and os.path.exists(log): + try: + extract_item('NotepadPlusPlus', silent=True) + popen_program( + [global_vars['Tools']['NotepadPlusPlus'], + global_vars['LogFile']]) + except Exception: + print_error('ERROR: Failed to extract Notepad++ and open log.') + pause('Press Enter to exit...') + + # Kill Caffeine if still running + kill_process('caffeine.exe') + + # Exit + sys.exit(return_value) + +def extract_item(item, filter='', silent=False): + """Extract item from .cbin into .bin.""" + cmd = [ + global_vars['Tools']['SevenZip'], 'x', '-aos', '-bso0', '-bse0', + '-p{ArchivePassword}'.format(**global_vars), + r'-o{BinDir}\{item}'.format(item=item, **global_vars), + r'{CBinDir}\{item}.7z'.format(item=item, **global_vars), + filter] + if not silent: + print_standard('Extracting "{item}"...'.format(item=item)) + try: + run_program(cmd) + except subprocess.CalledProcessError: + if not silent: + print_warning('WARNING: Errors encountered while exctracting data') + +def get_ticket_number(): + """Get TicketNumber from user, save in LogDir, and return as str.""" + ticket_number = None + while ticket_number is None: + _input = input('Enter ticket number: ') + if re.match(r'^([0-9]+([-_]?\w+|))$', _input): + ticket_number = _input + with open(r'{LogDir}\TicketNumber'.format(**global_vars), 'w') as f: + f.write(ticket_number) + return ticket_number + +def human_readable_size(size, decimals=0): + """Convert size in bytes to a human-readable format and return a str.""" + # Prep string formatting + width = 3+decimals + if decimals > 0: + width += 1 + + # Convert size to int + try: + size = int(size) + except ValueError: + size = convert_to_bytes(size) + + # Verify we have a valid size + if size <= 0: + return '{size:>{width}} b'.format(size='???', width=width) + + # Convert to sensible units + if size >= 1099511627776: + size /= 1099511627776 + units = 'Tb' + elif size >= 1073741824: + size /= 1073741824 + units = 'Gb' + elif size >= 1048576: + size /= 1048576 + units = 'Mb' + elif size >= 1024: + size /= 1024 + units = 'Kb' + else: + units = ' b' + + # Return + return '{size:>{width}.{decimals}f} {units}'.format( + size=size, width=width, decimals=decimals, units=units) + +def kill_process(name): + """Kill any running caffeine.exe processes.""" + for proc in psutil.process_iter(): + if proc.name() == name: + proc.kill() + +def major_exception(): + """Display traceback and exit""" + print_error('Major exception') + print_warning( + " Please let {tech} know and they'll look into it" + " (include the details below).".format(tech=SUPPORT_TECH)) + print(traceback.format_exc()) + print_log(traceback.format_exc()) + sleep(30) + pause('Press Enter to exit...') + # sys.exit(1) + exit_script(1) + +def menu_select(title='~ Untitled Menu ~', + prompt='Please make a selection', secret_exit=False, + main_entries=[], action_entries=[], disabled_label='DISABLED'): + """Display options in a menu and return selected option as a str.""" + # Bail early + if not main_entries and not action_entries: + raise Exception("MenuError: No items given") + + # Build menu + menu_splash = '{}\n\n'.format(title) + width = len(str(len(main_entries))) + valid_answers = [] + if (secret_exit): + valid_answers.append('Q') + + # Add main entries + for i in range(len(main_entries)): + entry = main_entries[i] + # Add Spacer + if ('CRLF' in entry): + menu_splash += '\n' + entry_str = '{number:>{width}}: {name}'.format( + number = i+1, + width = width, + name = entry.get('Display Name', entry['Name'])) + if entry.get('Disabled', False): + entry_str = '{YELLOW}{entry_str} ({disabled}){CLEAR}'.format( + entry_str = entry_str, + disabled = disabled_label, + **COLORS) + else: + valid_answers.append(str(i+1)) + menu_splash += '{}\n'.format(entry_str) + menu_splash += '\n' + + # Add action entries + for entry in action_entries: + # Add Spacer + if ('CRLF' in entry): + menu_splash += '\n' + valid_answers.append(entry['Letter']) + menu_splash += '{letter:>{width}}: {name}\n'.format( + letter = entry['Letter'].upper(), + width = len(str(len(action_entries))), + name = entry['Name']) + menu_splash += '\n' + + answer = '' + + while (answer.upper() not in valid_answers): + os.system('cls') + print(menu_splash) + answer = input('{}: '.format(prompt)) + + return answer.upper() + +def non_clobber_rename(full_path): + """Append suffix to path, if necessary, to avoid clobbering path""" + new_path = full_path + _i = 1; + while os.path.exists(new_path): + new_path = '{path}_{i}'.format(i=_i, path=full_path) + _i += 1 + + return new_path + +def pause(prompt='Press Enter to continue... '): + """Simple pause implementation.""" + input(prompt) + +def ping(addr='google.com'): + """Attempt to ping addr.""" + cmd = ['ping', '-n', '2', addr] + run_program(cmd) + +def popen_program(cmd, pipe=False, minimized=False, shell=False, **kwargs): + """Run program and return a subprocess.Popen object.""" + startupinfo=None + if minimized: + startupinfo = subprocess.STARTUPINFO() + startupinfo.dwFlags = subprocess.STARTF_USESHOWWINDOW + startupinfo.wShowWindow = 6 + + if pipe: + popen_obj = subprocess.Popen(cmd, shell=shell, startupinfo=startupinfo, + stdout=subprocess.PIPE, stderr=subprocess.PIPE) + else: + popen_obj = subprocess.Popen(cmd, shell=shell, startupinfo=startupinfo) + + return popen_obj + +def print_error(*args, **kwargs): + """Prints message to screen in RED.""" + print_standard(*args, color=COLORS['RED'], **kwargs) + +def print_info(*args, **kwargs): + """Prints message to screen in BLUE.""" + print_standard(*args, color=COLORS['BLUE'], **kwargs) + +def print_warning(*args, **kwargs): + """Prints message to screen in YELLOW.""" + print_standard(*args, color=COLORS['YELLOW'], **kwargs) + +def print_standard(message='Generic info', + color=None, end='\n', timestamp=True, **kwargs): + """Prints message to screen and log (if set).""" + display_message = message + if color: + display_message = color + message + COLORS['CLEAR'] + # **COLORS is used below to support non-"standard" color printing + print(display_message.format(**COLORS), end=end, **kwargs) + print_log(message, end, timestamp) + +def print_success(*args, **kwargs): + """Prints message to screen in GREEN.""" + print_standard(*args, color=COLORS['GREEN'], **kwargs) + +def print_log(message='', end='\n', timestamp=True): + time_str = time.strftime("%Y-%m-%d %H%M%z: ") if timestamp else '' + if 'LogFile' in global_vars and global_vars['LogFile'] is not None: + with open(global_vars['LogFile'], 'a') as f: + for line in message.splitlines(): + f.write('{timestamp}{line}{end}'.format( + timestamp = time_str, + line = line, + end = end)) + +def run_program(cmd, args=[], check=True, pipe=True, shell=False): + """Run program and return a subprocess.CompletedProcess object.""" + if args: + # Deprecated so let's raise an exception to find & fix all occurances + print_error('ERROR: Using args is no longer supported.') + raise Exception + cmd = [c for c in cmd if c] + if shell: + cmd = ' '.join(cmd) + + if pipe: + process_return = subprocess.run(cmd, check=check, shell=shell, + stdout=subprocess.PIPE, stderr=subprocess.PIPE) + else: + process_return = subprocess.run(cmd, check=check, shell=shell) + + return process_return + +def show_info(message='~Some message~', info='~Some info~', indent=8, width=32): + """Display info with formatting.""" + print_standard('{indent}{message:<{width}}{info}'.format( + indent=' '*indent, width=width, message=message, info=info)) + +def sleep(seconds=2): + """Wait for a while.""" + time.sleep(seconds) + +def stay_awake(): + """Prevent the system from sleeping or hibernating.""" + # Bail if caffeine is already running + for proc in psutil.process_iter(): + if proc.name() == 'caffeine.exe': + return + # Extract and run + extract_item('Caffeine', silent=True) + try: + popen_program(global_vars['Tools']['Caffeine']) + except Exception: + print_error('ERROR: No caffeine available.') + print_warning('Please set the power setting to High Performance.') + +def get_exception(s): + """Get exception by name, returns Exception object.""" + return getattr(sys.modules[__name__], s) + +def try_and_print(message='Trying...', + function=None, cs='CS', ns='NS', other_results={}, + catch_all=True, print_return=False, silent_function=True, + indent=8, width=32, *args, **kwargs): + """Run function, print if successful or not, and return dict. + + other_results is in the form of + { + 'Warning': {'ExceptionClassName': 'Result Message'}, + 'Error': {'ExceptionClassName': 'Result Message'} + } + The the ExceptionClassNames will be excepted conditions + and the result string will be printed in the correct color. + catch_all=False will result in unspecified exceptions being re-raised.""" + err = None + w_exceptions = other_results.get('Warning', {}).keys() + w_exceptions = tuple(get_exception(e) for e in w_exceptions) + e_exceptions = other_results.get('Error', {}).keys() + e_exceptions = tuple(get_exception(e) for e in e_exceptions) + w_results = other_results.get('Warning', {}) + e_results = other_results.get('Error', {}) + + # Run function and catch errors + print_standard('{indent}{message:<{width}}'.format( + indent=' '*indent, message=message, width=width), end='', flush=True) + try: + out = function(*args, **kwargs) + if print_return: + print_standard(out[0], timestamp=False) + for item in out[1:]: + print_standard('{indent}{item}'.format( + indent=' '*(indent+width), item=item)) + elif silent_function: + print_success(cs, timestamp=False) + except w_exceptions as e: + _result = w_results.get(e.__class__.__name__, 'Warning') + print_warning(_result, timestamp=False) + err = e + except e_exceptions as e: + _result = e_results.get(e.__class__.__name__, 'Error') + print_error(_result, timestamp=False) + err = e + except Exception: + print_error(ns, timestamp=False) + err = traceback.format_exc() + + # Return or raise? + if bool(err) and not catch_all: + raise + else: + return {'CS': not bool(err), 'Error': err} + +def upload_data(path, file): + """Add CLIENT_INFO_SERVER to authorized connections and upload file.""" + if not ENABLED_UPLOAD_DATA: + raise GenericError('Feature disabled.') + + extract_item('PuTTY', filter='wizkit.ppk psftp.exe', silent=True) + + # Authorize connection to the server + winreg.CreateKey(HKCU, r'Software\SimonTatham\PuTTY\SshHostKeys') + with winreg.OpenKey(HKCU, r'Software\SimonTatham\PuTTY\SshHostKeys', + access=winreg.KEY_WRITE) as key: + winreg.SetValueEx(key, + 'rsa2@22:{IP}'.format(**CLIENT_INFO_SERVER), 0, + winreg.REG_SZ, CLIENT_INFO_SERVER['RegEntry']) + + # Write batch file + with open(r'{TmpDir}\psftp.batch'.format(**global_vars), + 'w', encoding='ascii') as f: + f.write('lcd "{path}"\n'.format(path=path)) + f.write('cd "{Share}"\n'.format(**CLIENT_INFO_SERVER)) + f.write('mkdir {TicketNumber}\n'.format(**global_vars)) + f.write('cd {TicketNumber}\n'.format(**global_vars)) + f.write('put "{file}"\n'.format(file=file)) + + # Upload Info + cmd = [ + global_vars['Tools']['PuTTY-PSFTP'], + '-noagent', + '-i', r'{BinDir}\PuTTY\wizkit.ppk'.format(**global_vars), + '{User}@{IP}'.format(**CLIENT_INFO_SERVER), + '-b', r'{TmpDir}\psftp.batch'.format(**global_vars)] + run_program(cmd) + +def upload_info(): + """Upload compressed Info file to the NAS as set in settings.main.py.""" + if not ENABLED_UPLOAD_DATA: + raise GenericError('Feature disabled.') + + path = '{ClientDir}'.format(**global_vars) + file = 'Info_{Date-Time}.7z'.format(**global_vars) + upload_data(path, file) + +def compress_info(): + """Compress ClientDir info folders with 7-Zip for upload_info().""" + path = '{ClientDir}'.format(**global_vars) + file = 'Info_{Date-Time}.7z'.format(**global_vars) + _cmd = [ + global_vars['Tools']['SevenZip'], + 'a', '-t7z', '-mx=9', '-bso0', '-bse0', + r'{}\{}'.format(path, file), + r'{ClientDir}\Info'.format(**global_vars)] + run_program(_cmd) + +def wait_for_process(name, poll_rate=3): + """Wait for process by name.""" + running = True + while running: + sleep(poll_rate) + running = False + for proc in psutil.process_iter(): + if re.search(r'^{}'.format(name), proc.name(), re.IGNORECASE): + running = True + sleep(1) + +# global_vars functions +def init_global_vars(): + """Sets global variables based on system info.""" + print_info('Initializing') + os.system('title Wizard Kit') + init_functions = [ + ['Checking .bin...', find_bin], + ['Checking environment...', set_common_vars], + ['Checking OS...', check_os], + ['Checking tools...', check_tools], + ['Creating folders...', make_tmp_dirs], + ['Clearing collisions...', clean_env_vars], + ] + try: + for f in init_functions: + try_and_print( + message=f[0], function=f[1], + cs='Done', ns='Error', catch_all=False) + except: + major_exception() + +def check_os(): + """Set OS specific variables.""" + tmp = {} + + # Query registry + _reg_path = winreg.OpenKey( + HKLM, r'SOFTWARE\Microsoft\Windows NT\CurrentVersion') + for key in ['CSDVersion', 'CurrentBuild', 'CurrentBuildNumber', + 'CurrentVersion', 'ProductName']: + try: + tmp[key] = winreg.QueryValueEx(_reg_path, key)[0] + if key in ['CurrentBuild', 'CurrentBuildNumber']: + tmp[key] = int(tmp[key]) + except ValueError: + # Couldn't convert Build to int so this should be interesting... + tmp[key] = 0 + except Exception: + tmp[key] = 'Unknown' + + # Determine OS bit depth + tmp['Arch'] = 32 + if 'PROGRAMFILES(X86)' in global_vars['Env']: + tmp['Arch'] = 64 + + # Determine OS Name + tmp['Name'] = '{ProductName} {CSDVersion}'.format(**tmp) + if tmp['CurrentBuild'] == 9600: + tmp['Name'] += ' Update' # Win 8.1u + if tmp['CurrentBuild'] == 10240: + tmp['Name'] += ' Release 1507 "Threshold 1"' + if tmp['CurrentBuild'] == 10586: + tmp['Name'] += ' Release 1511 "Threshold 2"' + if tmp['CurrentBuild'] == 14393: + tmp['Name'] += ' Release 1607 "Redstone 1" / "Anniversary Update"' + if tmp['CurrentBuild'] == 15063: + tmp['Name'] += ' Release 1703 "Redstone 2" / "Creators Update"' + if tmp['CurrentBuild'] == 16299: + tmp['Name'] += ' Release 1709 "Redstone 3" / "Fall Creators Update"' + tmp['Name'] = tmp['Name'].replace('Service Pack ', 'SP') + tmp['Name'] = tmp['Name'].replace('Unknown Release', 'Release') + tmp['Name'] = re.sub(r'\s+', ' ', tmp['Name']) + + # Determine OS version + name = '{Name} x{Arch}'.format(**tmp) + if tmp['CurrentVersion'] == '6.0': + tmp['Version'] = 'Vista' + name += ' (very outdated)' + elif tmp['CurrentVersion'] == '6.1': + tmp['Version'] = '7' + if tmp['CSDVersion'] == 'Service Pack 1': + name += ' (outdated)' + else: + name += ' (very outdated)' + elif tmp['CurrentVersion'] in ['6.2', '6.3']: + if int(tmp['CurrentBuildNumber']) <= 9600: + tmp['Version'] = '8' + elif int(tmp['CurrentBuildNumber']) >= 10240: + tmp['Version'] = '10' + if tmp['CurrentBuild'] in [9200, 10240, 10586]: + name += ' (very outdated)' + elif tmp['CurrentBuild'] in [9600, 14393, 15063]: + name += ' (outdated)' + elif tmp['CurrentBuild'] == 16299: + pass # Current Win10 + else: + name += ' (unrecognized)' + tmp['DisplayName'] = name + + # == vista == + # 6.0.6000 + # 6.0.6001 + # 6.0.6002 + # ==== 7 ==== + # 6.1.7600 + # 6.1.7601 + # 6.1.7602 + # ==== 8 ==== + # 6.2.9200 + # === 8.1 === + # 6.3.9200 + # === 8.1u == + # 6.3.9600 + # === 10 v1507 "Threshold 1" == + # 6.3.10240 + # === 10 v1511 "Threshold 2" == + # 6.3.10586 + # === 10 v1607 "Redstone 1" "Anniversary Update" == + # 6.3.14393 + # === 10 v1703 "Redstone 2" "Creators Update" == + # 6.3.15063 + # === 10 v1709 "Redstone 3" "Fall Creators Update" == + # 6.3.16299 + global_vars['OS'] = tmp + +def check_tools(): + """Set tool variables based on OS bit-depth and tool availability.""" + if global_vars['OS'].get('Arch', 32) == 64: + global_vars['Tools'] = {k: v.get('64', v.get('32')) + for (k, v) in TOOLS.items()} + else: + global_vars['Tools'] = {k: v.get('32') for (k, v) in TOOLS.items()} + + # Fix paths + global_vars['Tools'] = {k: os.path.join(global_vars['BinDir'], v) + for (k, v) in global_vars['Tools'].items()} + +def clean_env_vars(): + """Remove conflicting global_vars and env variables. + + This fixes an issue where both global_vars and + global_vars['Env'] are expanded at the same time.""" + for key in global_vars.keys(): + global_vars['Env'].pop(key, None) + +def find_bin(): + """Find .bin folder in the cwd or it's parents.""" + wd = os.getcwd() + base = None + while base is None: + if os.path.exists('.bin'): + base = os.getcwd() + break + if re.fullmatch(r'\w:\\', os.getcwd()): + break + os.chdir('..') + os.chdir(wd) + if base is None: + raise BinNotFoundError + global_vars['BaseDir'] = base + +def make_tmp_dirs(): + """Make temp directories.""" + os.makedirs(global_vars['BackupDir'], exist_ok=True) + os.makedirs(global_vars['LogDir'], exist_ok=True) + os.makedirs(global_vars['TmpDir'], exist_ok=True) + +def set_common_vars(): + """Set common variables.""" + global_vars['Date'] = time.strftime("%Y-%m-%d") + global_vars['Date-Time'] = time.strftime("%Y-%m-%d_%H%M_%z") + global_vars['Env'] = os.environ.copy() + + global_vars['ArchivePassword'] = ARCHIVE_PASSWORD + global_vars['BinDir'] = r'{BaseDir}\.bin'.format( + **global_vars) + global_vars['CBinDir'] = r'{BaseDir}\.cbin'.format( + **global_vars) + global_vars['ClientDir'] = r'{SYSTEMDRIVE}\{prefix}'.format( + prefix=KIT_NAME_SHORT, **global_vars['Env']) + global_vars['BackupDir'] = r'{ClientDir}\Backups\{Date}'.format( + **global_vars) + global_vars['LogDir'] = r'{ClientDir}\Info\{Date}'.format( + **global_vars) + global_vars['ProgBackupDir'] = r'{ClientDir}\Backups'.format( + **global_vars) + global_vars['QuarantineDir'] = r'{ClientDir}\Quarantine'.format( + **global_vars) + global_vars['TmpDir'] = r'{BinDir}\tmp'.format( + **global_vars) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/data.py b/.bin/Scripts/functions/data.py index 8e91d6b1..72bb14dc 100644 --- a/.bin/Scripts/functions/data.py +++ b/.bin/Scripts/functions/data.py @@ -1,608 +1,608 @@ -# Wizard Kit: Functions - Data - -import ctypes - -from operator import itemgetter - -from functions.common import * - -# Classes -class LocalDisk(): - def __init__(self, disk): - self.disk = disk - self.name = disk.mountpoint.upper() - self.path = self.name - def is_dir(self): - # Should always be true - return True - -# Regex -REGEX_EXCL_ITEMS = re.compile( - r'^(\.(AppleDB|AppleDesktop|AppleDouble' - r'|com\.apple\.timemachine\.supported|dbfseventsd' - r'|DocumentRevisions-V100.*|DS_Store|fseventsd|PKInstallSandboxManager' - r'|Spotlight.*|SymAV.*|symSchedScanLockxz|TemporaryItems|Trash.*' - r'|vol|VolumeIcon\.icns)|desktop\.(ini|.*DB|.*DF)' - r'|(hiberfil|pagefile)\.sys|lost\+found|Network\.*Trash\.*Folder' - r'|Recycle[dr]|System\.*Volume\.*Information|Temporary\.*Items' - r'|Thumbs\.db)$', - re.IGNORECASE) -REGEX_EXCL_ROOT_ITEMS = re.compile( - r'^\\?(boot(mgr|nxt)$|Config.msi' - r'|(eula|globdata|install|vc_?red)' - r'|.*.sys$|System Volume Information|RECYCLER?|\$Recycle\.bin' - r'|\$?Win(dows(.old.*|\.~BT|)$|RE_)|\$GetCurrent|Windows10Upgrade' - r'|PerfLogs|Program Files|SYSTEM.SAV' - r'|.*\.(esd|swm|wim|dd|map|dmg|image)$)', - re.IGNORECASE) -REGEX_INCL_ROOT_ITEMS = re.compile( - r'^\\?(AdwCleaner|(My\s*|)(Doc(uments?( and Settings|)|s?)|Downloads' - r'|Media|Music|Pic(ture|)s?|Vid(eo|)s?)' - r'|{prefix}(-?Info|-?Transfer|)' - r'|(ProgramData|Recovery|Temp.*|Users)$' - r'|.*\.(log|txt|rtf|qb\w*|avi|m4a|m4v|mp4|mkv|jpg|png|tiff?)$)' - r''.format(prefix=KIT_NAME_SHORT), - re.IGNORECASE) -REGEX_WIM_FILE = re.compile( - r'\.wim$', - re.IGNORECASE) -REGEX_WINDOWS_OLD = re.compile( - r'^\\Win(dows|)\.old', - re.IGNORECASE) - -# STATIC VARIABLES -FAST_COPY_EXCLUDES = [ - r'\*.esd', - r'\*.swm', - r'\*.wim', - r'\*.dd', - r'\*.dd.tgz', - r'\*.dd.txz', - r'\*.map', - r'\*.dmg', - r'\*.image', - r'$RECYCLE.BIN', - r'$Recycle.Bin', - r'.AppleDB', - r'.AppleDesktop', - r'.AppleDouble', - r'.com.apple.timemachine.supported', - r'.dbfseventsd', - r'.DocumentRevisions-V100*', - r'.DS_Store', - r'.fseventsd', - r'.PKInstallSandboxManager', - r'.Spotlight*', - r'.SymAV*', - r'.symSchedScanLockxz', - r'.TemporaryItems', - r'.Trash*', - r'.vol', - r'.VolumeIcon.icns', - r'desktop.ini', - r'Desktop?DB', - r'Desktop?DF', - r'hiberfil.sys', - r'lost+found', - r'Network?Trash?Folder', - r'pagefile.sys', - r'Recycled', - r'RECYCLER', - r'System?Volume?Information', - r'Temporary?Items', - r'Thumbs.db', - ] -FAST_COPY_ARGS = [ - '/cmd=noexist_only', - '/utf8', - '/skip_empty_dir', - '/linkdest', - '/no_ui', - '/auto_close', - '/exclude='+';'.join(FAST_COPY_EXCLUDES), - ] -# Code borrowed from: https://stackoverflow.com/a/29075319 -SEM_NORMAL = ctypes.c_uint() -SEM_FAILCRITICALERRORS = 1 -SEM_NOOPENFILEERRORBOX = 0x8000 -SEM_FAIL = SEM_NOOPENFILEERRORBOX | SEM_FAILCRITICALERRORS - -def cleanup_transfer(dest_path): - """Fix attributes and move extraneous items outside the Transfer folder.""" - try: - # Remove dest_path if empty - os.rmdir(dest_path) - except OSError: - pass - if not os.path.exists(dest_path): - # Bail if dest_path was empty and removed - raise Exception - - # Fix attributes - cmd = ['attrib', '-a', '-h', '-r', '-s', dest_path] - run_program(cmd, check=False) - - for root, dirs, files in os.walk(dest_path, topdown=False): - for name in dirs: - # Remove empty directories and junction points - try: - os.rmdir(os.path.join(root, name)) - except OSError: - pass - for name in files: - # "Remove" files based on exclusion regex - if REGEX_EXCL_ITEMS.search(name): - # Make dest folder - dest_name = root.replace(dest_path, dest_path+'.Removed') - os.makedirs(dest_name, exist_ok=True) - # Set dest filename - dest_name = os.path.join(dest_name, name) - dest_name = non_clobber_rename(dest_name) - source_name = os.path.join(root, name) - try: - shutil.move(source_name, dest_name) - except Exception: - pass - -def is_valid_wim_file(item): - """Checks if the provided os.DirEntry is a valid WIM file, returns bool.""" - valid = bool(item.is_file() and REGEX_WIM_FILE.search(item.name)) - if valid: - extract_item('wimlib', silent=True) - cmd = [global_vars['Tools']['wimlib-imagex'], 'info', item.path] - try: - run_program(cmd) - except subprocess.CalledProcessError: - valid = False - print_log('WARNING: Image "{}" damaged.'.format(item.name)) - return valid - -def mount_backup_shares(): - """Mount the backup shares unless labeled as already mounted.""" - for server in BACKUP_SERVERS: - # Blindly skip if we mounted earlier - if server['Mounted']: - continue - - mount_network_share(server) - - -def mount_network_share(server): - """Mount a network share defined by server.""" - # Test connection - try: - ping(server['IP']) - except subprocess.CalledProcessError: - print_error( - r'Failed to mount \\{Name}\{Share}, {IP} unreachable.'.format( - **server)) - sleep(1) - return False - - # Mount - cmd = r'net use \\{IP}\{Share} /user:{User} {Pass}'.format(**server) - cmd = cmd.split(' ') - try: - run_program(cmd) - except Exception: - print_warning(r'Failed to mount \\{Name}\{Share} ({IP})'.format( - **server)) - sleep(1) - else: - print_info('Mounted {Name}'.format(**server)) - server['Mounted'] = True - -def run_fast_copy(items, dest): - """Copy items to dest using FastCopy.""" - if not items: - raise Exception - - cmd = [global_vars['Tools']['FastCopy'], *FAST_COPY_ARGS] - if 'LogFile' in global_vars: - cmd.append('/logfile={LogFile}'.format(**global_vars)) - cmd.extend(items) - cmd.append('/to={}\\'.format(dest)) - - run_program(cmd) - -def run_wimextract(source, items, dest): - """Extract items from source WIM to dest folder.""" - if not items: - raise Exception - extract_item('wimlib', silent=True) - - # Write files.txt - with open(r'{TmpDir}\wim_files.txt'.format(**global_vars), 'w') as f: - # Defaults - for item in items: - f.write('{item}\n'.format(item=item)) - sleep(1) # For safety? - - # Extract files - cmd = [ - global_vars['Tools']['wimlib-imagex'], - 'extract', - source, '1', - r'@{TmpDir}\wim_files.txt'.format(**global_vars), - '--dest-dir={}\\'.format(dest), - '--no-acls', - '--nullglob'] - run_program(cmd) - -def scan_source(source_obj, dest_path): - """Scan source for files/folders to transfer.""" - selected_items = [] - - if source_obj.is_dir(): - # File-Based - print_standard('Scanning source (folder): {}'.format(source_obj.path)) - selected_items = scan_source_path(source_obj.path, dest_path) - else: - # Image-Based - if REGEX_WIM_FILE.search(source_obj.name): - print_standard('Scanning source (image): {}'.format( - source_obj.path)) - selected_items = scan_source_wim(source_obj.path, dest_path) - else: - print_error('ERROR: Unsupported image: {}'.format( - source_obj.path)) - raise GenericError - - return selected_items - -def scan_source_path(source_path, dest_path, rel_path=None, interactive=True): - """Scan source folder for files/folders to transfer. - - This will scan the root and (recursively) any Windows.old folders.""" - rel_path = '\\' + rel_path if rel_path else '' - if rel_path: - dest_path = dest_path + rel_path - selected_items = [] - win_olds = [] - - # Root items - root_items = [] - for item in os.scandir(source_path): - if REGEX_INCL_ROOT_ITEMS.search(item.name): - root_items.append(item.path) - elif not REGEX_EXCL_ROOT_ITEMS.search(item.name): - if (not interactive - or ask('Copy: "{}{}" ?'.format(rel_path, item.name))): - root_items.append(item.path) - if REGEX_WINDOWS_OLD.search(item.name): - win_olds.append(item) - if root_items: - selected_items.append({ - 'Message': '{}Root Items...'.format(rel_path), - 'Items': root_items.copy(), - 'Destination': dest_path}) - - # Fonts - if os.path.exists(r'{}\Windows\Fonts'.format(source_path)): - selected_items.append({ - 'Message': '{}Fonts...'.format(rel_path), - 'Items': [r'{}\Windows\Fonts'.format(rel_path)], - 'Destination': r'{}\Windows'.format(dest_path)}) - - # Registry - registry_items = [] - for folder in ['config', 'OEM']: - folder = r'Windows\System32\{}'.format(folder) - folder = os.path.join(source_path, folder) - if os.path.exists(folder): - registry_items.append(folder) - if registry_items: - selected_items.append({ - 'Message': '{}Registry...'.format(rel_path), - 'Items': registry_items.copy(), - 'Destination': r'{}\Windows\System32'.format(dest_path)}) - - # Windows.old(s) - for old in win_olds: - selected_items.append( - scan_source_path( - old.path, dest_path, rel_path=old.name, interactive=False)) - - # Done - return selected_items - -def scan_source_wim(source_wim, dest_path, rel_path=None, interactive=True): - """Scan source WIM file for files/folders to transfer. - - This will scan the root and (recursively) any Windows.old folders.""" - rel_path = '\\' + rel_path if rel_path else '' - selected_items = [] - win_olds = [] - - # Scan source - extract_item('wimlib', silent=True) - cmd = [ - global_vars['Tools']['wimlib-imagex'], 'dir', - source_wim, '1'] - try: - file_list = run_program(cmd) - except subprocess.CalledProcessError: - print_error('ERROR: Failed to get file list.') - raise - - # Root Items - file_list = [i.strip() - for i in file_list.stdout.decode('utf-8', 'ignore').splitlines() - if i.count('\\') == 1 and i.strip() != '\\'] - root_items = [] - if rel_path: - file_list = [i.replace(rel_path, '') for i in file_list] - for item in file_list: - if REGEX_INCL_ROOT_ITEMS.search(item): - root_items.append(item) - elif not REGEX_EXCL_ROOT_ITEMS.search(item): - if (not interactive - or ask('Extract: "{}{}" ?'.format(rel_path, item))): - root_items.append('{}{}'.format(rel_path, item)) - if REGEX_WINDOWS_OLD.search(item): - win_olds.append(item) - if root_items: - selected_items.append({ - 'Message': '{}Root Items...'.format(rel_path), - 'Items': root_items.copy(), - 'Destination': dest_path}) - - # Fonts - if wim_contains(source_wim, r'{}Windows\Fonts'.format(rel_path)): - selected_items.append({ - 'Message': '{}Fonts...'.format(rel_path), - 'Items': [r'{}\Windows\Fonts'.format(rel_path)], - 'Destination': dest_path}) - - # Registry - registry_items = [] - for folder in ['config', 'OEM']: - folder = r'{}Windows\System32\{}'.format(rel_path, folder) - if wim_contains(source_wim, folder): - registry_items.append(folder) - if registry_items: - selected_items.append({ - 'Message': '{}Registry...'.format(rel_path), - 'Items': registry_items.copy(), - 'Destination': dest_path}) - - # Windows.old(s) - for old in win_olds: - scan_source_wim(source_wim, dest_path, rel_path=old, interactive=False) - - # Done - return selected_items - -def select_destination(folder_path, prompt='Select destination'): - """Select destination drive, returns path as string.""" - disk = select_disk(prompt) - if 'fixed' not in disk['Disk'].opts: - folder_path = folder_path.replace('\\', '-') - path = '{disk}{folder_path}_{Date}'.format( - disk = disk['Disk'].mountpoint, - folder_path = folder_path, - **global_vars) - - # Avoid merging with existing folder - path = non_clobber_rename(path) - os.makedirs(path, exist_ok=True) - - return path - -def select_disk(title='Select disk', auto_select=True): - """Select disk from attached disks. returns dict.""" - actions = [{'Name': 'Quit', 'Letter': 'Q'}] - disks = [] - - # Build list of disks - set_thread_error_mode(silent=True) # Prevents "No disk" popups - for d in psutil.disk_partitions(): - info = { - 'Disk': d, - 'Name': d.mountpoint} - try: - usage = psutil.disk_usage(d.device) - free = '{free} / {total} available'.format( - free = human_readable_size(usage.free, 2), - total = human_readable_size(usage.total, 2)) - except Exception: - # Meh, leaving unsupported destinations out - pass - # free = 'Unknown' - # info['Disabled'] = True - else: - info['Display Name'] = '{} ({})'.format(info['Name'], free) - disks.append(info) - set_thread_error_mode(silent=False) # Return to normal - - # Skip menu? - if len(disks) == 1 and auto_select: - return disks[0] - - # Show menu - selection = menu_select(title, main_entries=disks, action_entries=actions) - if selection == 'Q': - exit_script() - else: - return disks[int(selection)-1] - -def select_source(ticket_number): - """Select backup from those found on the BACKUP_SERVERS for the ticket.""" - selected_source = None - sources = [] - mount_backup_shares() - - # Check for ticket folders on servers - for server in BACKUP_SERVERS: - if server['Mounted']: - print_standard('Scanning {}...'.format(server['Name'])) - for d in os.scandir(r'\\{IP}\{Share}'.format(**server)): - if (d.is_dir() - and d.name.lower().startswith(ticket_number.lower())): - # Add folder to sources - sources.append({ - 'Name': '{:9}| File-Based: [DIR] {}'.format( - server['Name'], d.name), - 'Server': server, - 'Source': d}) - - # Check for images and subfolders - for ticket_path in sources.copy(): - for item in os.scandir(ticket_path['Source'].path): - if item.is_dir(): - # Add folder to sources - sources.append({ - 'Name': r'{:9}| File-Based: [DIR] {}\{}'.format( - ticket_path['Server']['Name'], # Server - ticket_path['Source'].name, # Ticket folder - item.name, # Sub-folder - ), - 'Server': ticket_path['Server'], - 'Source': item}) - - # Check for images in folder - for subitem in os.scandir(item.path): - if REGEX_WIM_FILE.search(item.name): - # Add image to sources - try: - size = human_readable_size(item.stat().st_size) - except Exception: - size = ' ? ?' # unknown - sources.append({ - 'Disabled': bool(not is_valid_wim_file(subitem)), - 'Name': r'{:9}| Image-Based: {:>7} {}\{}\{}'.format( - ticket_path['Server']['Name'], # Server - size, # Size (duh) - ticket_path['Source'].name, # Ticket folder - item.name, # Sub-folder - subitem.name, # Image file - ), - 'Server': ticket_path['Server'], - 'Source': subitem}) - elif REGEX_WIM_FILE.search(item.name): - # Add image to sources - try: - size = human_readable_size(item.stat().st_size) - except Exception: - size = ' ? ?' # unknown - sources.append({ - 'Disabled': bool(not is_valid_wim_file(item)), - 'Name': r'{:9}| Image-Based: {:>7} {}\{}'.format( - ticket_path['Server']['Name'], # Server - size, # Size (duh) - ticket_path['Source'].name, # Ticket folder - item.name, # Image file - ), - 'Server': ticket_path['Server'], - 'Source': item}) - # Check for local sources - print_standard('Scanning for local sources...') - set_thread_error_mode(silent=True) # Prevents "No disk" popups - sys_drive = global_vars['Env']['SYSTEMDRIVE'] - for d in psutil.disk_partitions(): - if re.search(r'^{}'.format(sys_drive), d.mountpoint, re.IGNORECASE): - # Skip current OS drive - continue - if 'fixed' in d.opts: - # Skip DVD, etc - sources.append({ - 'Name': '{:9}| File-Based: [DISK] {}'.format( - ' Local', d.mountpoint), - 'Source': LocalDisk(d)}) - set_thread_error_mode(silent=False) # Return to normal - - # Build Menu - sources.sort(key=itemgetter('Name')) - actions = [{'Name': 'Quit', 'Letter': 'Q'}] - - # Select backup from sources - if len(sources) > 0: - selection = menu_select( - 'Which backup are we using?', - main_entries=sources, - action_entries=actions, - disabled_label='DAMAGED') - if selection == 'Q': - umount_backup_shares() - exit_script() - else: - selected_source = sources[int(selection)-1]['Source'] - else: - print_error('ERROR: No backups found for ticket: {}.'.format( - ticket_number)) - umount_backup_shares() - pause("Press Enter to exit...") - exit_script() - - # Done - return selected_source - -def set_thread_error_mode(silent=True): - """Disable or Enable Windows error message dialogs. - - Disable when scanning for disks to avoid popups for empty cardreaders, etc - """ - # Code borrowed from: https://stackoverflow.com/a/29075319 - kernel32 = ctypes.WinDLL('kernel32') - - if silent: - kernel32.SetThreadErrorMode(SEM_FAIL, ctypes.byref(SEM_NORMAL)) - else: - kernel32.SetThreadErrorMode(SEM_NORMAL, ctypes.byref(SEM_NORMAL)) - -def transfer_source(source_obj, dest_path, selected_items): - """Transfer, or extract, files/folders from source to destination.""" - if source_obj.is_dir(): - # Run FastCopy for each selection "group" - for group in selected_items: - try_and_print(message=group['Message'], - function=run_fast_copy, cs='Done', - items=group['Items'], - dest=group['Destination']) - else: - if REGEX_WIM_FILE.search(source_obj.name): - # Extract files from WIM - for group in selected_items: - try_and_print(message=group['Message'], - function=run_wimextract, cs='Done', - source=source_obj.path, - items=group['Items'], - dest=group['Destination']) - else: - print_error('ERROR: Unsupported image: {}'.format(source_obj.path)) - raise GenericError - -def umount_backup_shares(): - """Unnount the backup shares regardless of current status.""" - for server in BACKUP_SERVERS: - umount_network_share(server) - -def umount_network_share(server): - """Unnount a network share defined by server.""" - cmd = r'net use \\{IP}\{Share} /delete'.format(**server) - cmd = cmd.split(' ') - try: - run_program(cmd) - except Exception: - print_error(r'Failed to umount \\{Name}\{Share}.'.format(**server)) - sleep(1) - else: - print_info('Umounted {Name}'.format(**server)) - server['Mounted'] = False - -def wim_contains(source_path, file_path): - """Check if the WIM contains a file or folder.""" - _cmd = [ - global_vars['Tools']['wimlib-imagex'], 'dir', - source_path, '1', - '--path={}'.format(file_path), - '--one-file-only'] - try: - run_program(_cmd) - except subprocess.CalledProcessError: - return False - else: - return True - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Data + +import ctypes + +from operator import itemgetter + +from functions.common import * + +# Classes +class LocalDisk(): + def __init__(self, disk): + self.disk = disk + self.name = disk.mountpoint.upper() + self.path = self.name + def is_dir(self): + # Should always be true + return True + +# Regex +REGEX_EXCL_ITEMS = re.compile( + r'^(\.(AppleDB|AppleDesktop|AppleDouble' + r'|com\.apple\.timemachine\.supported|dbfseventsd' + r'|DocumentRevisions-V100.*|DS_Store|fseventsd|PKInstallSandboxManager' + r'|Spotlight.*|SymAV.*|symSchedScanLockxz|TemporaryItems|Trash.*' + r'|vol|VolumeIcon\.icns)|desktop\.(ini|.*DB|.*DF)' + r'|(hiberfil|pagefile)\.sys|lost\+found|Network\.*Trash\.*Folder' + r'|Recycle[dr]|System\.*Volume\.*Information|Temporary\.*Items' + r'|Thumbs\.db)$', + re.IGNORECASE) +REGEX_EXCL_ROOT_ITEMS = re.compile( + r'^\\?(boot(mgr|nxt)$|Config.msi' + r'|(eula|globdata|install|vc_?red)' + r'|.*.sys$|System Volume Information|RECYCLER?|\$Recycle\.bin' + r'|\$?Win(dows(.old.*|\.~BT|)$|RE_)|\$GetCurrent|Windows10Upgrade' + r'|PerfLogs|Program Files|SYSTEM.SAV' + r'|.*\.(esd|swm|wim|dd|map|dmg|image)$)', + re.IGNORECASE) +REGEX_INCL_ROOT_ITEMS = re.compile( + r'^\\?(AdwCleaner|(My\s*|)(Doc(uments?( and Settings|)|s?)|Downloads' + r'|Media|Music|Pic(ture|)s?|Vid(eo|)s?)' + r'|{prefix}(-?Info|-?Transfer|)' + r'|(ProgramData|Recovery|Temp.*|Users)$' + r'|.*\.(log|txt|rtf|qb\w*|avi|m4a|m4v|mp4|mkv|jpg|png|tiff?)$)' + r''.format(prefix=KIT_NAME_SHORT), + re.IGNORECASE) +REGEX_WIM_FILE = re.compile( + r'\.wim$', + re.IGNORECASE) +REGEX_WINDOWS_OLD = re.compile( + r'^\\Win(dows|)\.old', + re.IGNORECASE) + +# STATIC VARIABLES +FAST_COPY_EXCLUDES = [ + r'\*.esd', + r'\*.swm', + r'\*.wim', + r'\*.dd', + r'\*.dd.tgz', + r'\*.dd.txz', + r'\*.map', + r'\*.dmg', + r'\*.image', + r'$RECYCLE.BIN', + r'$Recycle.Bin', + r'.AppleDB', + r'.AppleDesktop', + r'.AppleDouble', + r'.com.apple.timemachine.supported', + r'.dbfseventsd', + r'.DocumentRevisions-V100*', + r'.DS_Store', + r'.fseventsd', + r'.PKInstallSandboxManager', + r'.Spotlight*', + r'.SymAV*', + r'.symSchedScanLockxz', + r'.TemporaryItems', + r'.Trash*', + r'.vol', + r'.VolumeIcon.icns', + r'desktop.ini', + r'Desktop?DB', + r'Desktop?DF', + r'hiberfil.sys', + r'lost+found', + r'Network?Trash?Folder', + r'pagefile.sys', + r'Recycled', + r'RECYCLER', + r'System?Volume?Information', + r'Temporary?Items', + r'Thumbs.db', + ] +FAST_COPY_ARGS = [ + '/cmd=noexist_only', + '/utf8', + '/skip_empty_dir', + '/linkdest', + '/no_ui', + '/auto_close', + '/exclude='+';'.join(FAST_COPY_EXCLUDES), + ] +# Code borrowed from: https://stackoverflow.com/a/29075319 +SEM_NORMAL = ctypes.c_uint() +SEM_FAILCRITICALERRORS = 1 +SEM_NOOPENFILEERRORBOX = 0x8000 +SEM_FAIL = SEM_NOOPENFILEERRORBOX | SEM_FAILCRITICALERRORS + +def cleanup_transfer(dest_path): + """Fix attributes and move extraneous items outside the Transfer folder.""" + try: + # Remove dest_path if empty + os.rmdir(dest_path) + except OSError: + pass + if not os.path.exists(dest_path): + # Bail if dest_path was empty and removed + raise Exception + + # Fix attributes + cmd = ['attrib', '-a', '-h', '-r', '-s', dest_path] + run_program(cmd, check=False) + + for root, dirs, files in os.walk(dest_path, topdown=False): + for name in dirs: + # Remove empty directories and junction points + try: + os.rmdir(os.path.join(root, name)) + except OSError: + pass + for name in files: + # "Remove" files based on exclusion regex + if REGEX_EXCL_ITEMS.search(name): + # Make dest folder + dest_name = root.replace(dest_path, dest_path+'.Removed') + os.makedirs(dest_name, exist_ok=True) + # Set dest filename + dest_name = os.path.join(dest_name, name) + dest_name = non_clobber_rename(dest_name) + source_name = os.path.join(root, name) + try: + shutil.move(source_name, dest_name) + except Exception: + pass + +def is_valid_wim_file(item): + """Checks if the provided os.DirEntry is a valid WIM file, returns bool.""" + valid = bool(item.is_file() and REGEX_WIM_FILE.search(item.name)) + if valid: + extract_item('wimlib', silent=True) + cmd = [global_vars['Tools']['wimlib-imagex'], 'info', item.path] + try: + run_program(cmd) + except subprocess.CalledProcessError: + valid = False + print_log('WARNING: Image "{}" damaged.'.format(item.name)) + return valid + +def mount_backup_shares(): + """Mount the backup shares unless labeled as already mounted.""" + for server in BACKUP_SERVERS: + # Blindly skip if we mounted earlier + if server['Mounted']: + continue + + mount_network_share(server) + + +def mount_network_share(server): + """Mount a network share defined by server.""" + # Test connection + try: + ping(server['IP']) + except subprocess.CalledProcessError: + print_error( + r'Failed to mount \\{Name}\{Share}, {IP} unreachable.'.format( + **server)) + sleep(1) + return False + + # Mount + cmd = r'net use \\{IP}\{Share} /user:{User} {Pass}'.format(**server) + cmd = cmd.split(' ') + try: + run_program(cmd) + except Exception: + print_warning(r'Failed to mount \\{Name}\{Share} ({IP})'.format( + **server)) + sleep(1) + else: + print_info('Mounted {Name}'.format(**server)) + server['Mounted'] = True + +def run_fast_copy(items, dest): + """Copy items to dest using FastCopy.""" + if not items: + raise Exception + + cmd = [global_vars['Tools']['FastCopy'], *FAST_COPY_ARGS] + if 'LogFile' in global_vars: + cmd.append('/logfile={LogFile}'.format(**global_vars)) + cmd.extend(items) + cmd.append('/to={}\\'.format(dest)) + + run_program(cmd) + +def run_wimextract(source, items, dest): + """Extract items from source WIM to dest folder.""" + if not items: + raise Exception + extract_item('wimlib', silent=True) + + # Write files.txt + with open(r'{TmpDir}\wim_files.txt'.format(**global_vars), 'w') as f: + # Defaults + for item in items: + f.write('{item}\n'.format(item=item)) + sleep(1) # For safety? + + # Extract files + cmd = [ + global_vars['Tools']['wimlib-imagex'], + 'extract', + source, '1', + r'@{TmpDir}\wim_files.txt'.format(**global_vars), + '--dest-dir={}\\'.format(dest), + '--no-acls', + '--nullglob'] + run_program(cmd) + +def scan_source(source_obj, dest_path): + """Scan source for files/folders to transfer.""" + selected_items = [] + + if source_obj.is_dir(): + # File-Based + print_standard('Scanning source (folder): {}'.format(source_obj.path)) + selected_items = scan_source_path(source_obj.path, dest_path) + else: + # Image-Based + if REGEX_WIM_FILE.search(source_obj.name): + print_standard('Scanning source (image): {}'.format( + source_obj.path)) + selected_items = scan_source_wim(source_obj.path, dest_path) + else: + print_error('ERROR: Unsupported image: {}'.format( + source_obj.path)) + raise GenericError + + return selected_items + +def scan_source_path(source_path, dest_path, rel_path=None, interactive=True): + """Scan source folder for files/folders to transfer. + + This will scan the root and (recursively) any Windows.old folders.""" + rel_path = '\\' + rel_path if rel_path else '' + if rel_path: + dest_path = dest_path + rel_path + selected_items = [] + win_olds = [] + + # Root items + root_items = [] + for item in os.scandir(source_path): + if REGEX_INCL_ROOT_ITEMS.search(item.name): + root_items.append(item.path) + elif not REGEX_EXCL_ROOT_ITEMS.search(item.name): + if (not interactive + or ask('Copy: "{}{}" ?'.format(rel_path, item.name))): + root_items.append(item.path) + if REGEX_WINDOWS_OLD.search(item.name): + win_olds.append(item) + if root_items: + selected_items.append({ + 'Message': '{}Root Items...'.format(rel_path), + 'Items': root_items.copy(), + 'Destination': dest_path}) + + # Fonts + if os.path.exists(r'{}\Windows\Fonts'.format(source_path)): + selected_items.append({ + 'Message': '{}Fonts...'.format(rel_path), + 'Items': [r'{}\Windows\Fonts'.format(rel_path)], + 'Destination': r'{}\Windows'.format(dest_path)}) + + # Registry + registry_items = [] + for folder in ['config', 'OEM']: + folder = r'Windows\System32\{}'.format(folder) + folder = os.path.join(source_path, folder) + if os.path.exists(folder): + registry_items.append(folder) + if registry_items: + selected_items.append({ + 'Message': '{}Registry...'.format(rel_path), + 'Items': registry_items.copy(), + 'Destination': r'{}\Windows\System32'.format(dest_path)}) + + # Windows.old(s) + for old in win_olds: + selected_items.append( + scan_source_path( + old.path, dest_path, rel_path=old.name, interactive=False)) + + # Done + return selected_items + +def scan_source_wim(source_wim, dest_path, rel_path=None, interactive=True): + """Scan source WIM file for files/folders to transfer. + + This will scan the root and (recursively) any Windows.old folders.""" + rel_path = '\\' + rel_path if rel_path else '' + selected_items = [] + win_olds = [] + + # Scan source + extract_item('wimlib', silent=True) + cmd = [ + global_vars['Tools']['wimlib-imagex'], 'dir', + source_wim, '1'] + try: + file_list = run_program(cmd) + except subprocess.CalledProcessError: + print_error('ERROR: Failed to get file list.') + raise + + # Root Items + file_list = [i.strip() + for i in file_list.stdout.decode('utf-8', 'ignore').splitlines() + if i.count('\\') == 1 and i.strip() != '\\'] + root_items = [] + if rel_path: + file_list = [i.replace(rel_path, '') for i in file_list] + for item in file_list: + if REGEX_INCL_ROOT_ITEMS.search(item): + root_items.append(item) + elif not REGEX_EXCL_ROOT_ITEMS.search(item): + if (not interactive + or ask('Extract: "{}{}" ?'.format(rel_path, item))): + root_items.append('{}{}'.format(rel_path, item)) + if REGEX_WINDOWS_OLD.search(item): + win_olds.append(item) + if root_items: + selected_items.append({ + 'Message': '{}Root Items...'.format(rel_path), + 'Items': root_items.copy(), + 'Destination': dest_path}) + + # Fonts + if wim_contains(source_wim, r'{}Windows\Fonts'.format(rel_path)): + selected_items.append({ + 'Message': '{}Fonts...'.format(rel_path), + 'Items': [r'{}\Windows\Fonts'.format(rel_path)], + 'Destination': dest_path}) + + # Registry + registry_items = [] + for folder in ['config', 'OEM']: + folder = r'{}Windows\System32\{}'.format(rel_path, folder) + if wim_contains(source_wim, folder): + registry_items.append(folder) + if registry_items: + selected_items.append({ + 'Message': '{}Registry...'.format(rel_path), + 'Items': registry_items.copy(), + 'Destination': dest_path}) + + # Windows.old(s) + for old in win_olds: + scan_source_wim(source_wim, dest_path, rel_path=old, interactive=False) + + # Done + return selected_items + +def select_destination(folder_path, prompt='Select destination'): + """Select destination drive, returns path as string.""" + disk = select_disk(prompt) + if 'fixed' not in disk['Disk'].opts: + folder_path = folder_path.replace('\\', '-') + path = '{disk}{folder_path}_{Date}'.format( + disk = disk['Disk'].mountpoint, + folder_path = folder_path, + **global_vars) + + # Avoid merging with existing folder + path = non_clobber_rename(path) + os.makedirs(path, exist_ok=True) + + return path + +def select_disk(title='Select disk', auto_select=True): + """Select disk from attached disks. returns dict.""" + actions = [{'Name': 'Quit', 'Letter': 'Q'}] + disks = [] + + # Build list of disks + set_thread_error_mode(silent=True) # Prevents "No disk" popups + for d in psutil.disk_partitions(): + info = { + 'Disk': d, + 'Name': d.mountpoint} + try: + usage = psutil.disk_usage(d.device) + free = '{free} / {total} available'.format( + free = human_readable_size(usage.free, 2), + total = human_readable_size(usage.total, 2)) + except Exception: + # Meh, leaving unsupported destinations out + pass + # free = 'Unknown' + # info['Disabled'] = True + else: + info['Display Name'] = '{} ({})'.format(info['Name'], free) + disks.append(info) + set_thread_error_mode(silent=False) # Return to normal + + # Skip menu? + if len(disks) == 1 and auto_select: + return disks[0] + + # Show menu + selection = menu_select(title, main_entries=disks, action_entries=actions) + if selection == 'Q': + exit_script() + else: + return disks[int(selection)-1] + +def select_source(ticket_number): + """Select backup from those found on the BACKUP_SERVERS for the ticket.""" + selected_source = None + sources = [] + mount_backup_shares() + + # Check for ticket folders on servers + for server in BACKUP_SERVERS: + if server['Mounted']: + print_standard('Scanning {}...'.format(server['Name'])) + for d in os.scandir(r'\\{IP}\{Share}'.format(**server)): + if (d.is_dir() + and d.name.lower().startswith(ticket_number.lower())): + # Add folder to sources + sources.append({ + 'Name': '{:9}| File-Based: [DIR] {}'.format( + server['Name'], d.name), + 'Server': server, + 'Source': d}) + + # Check for images and subfolders + for ticket_path in sources.copy(): + for item in os.scandir(ticket_path['Source'].path): + if item.is_dir(): + # Add folder to sources + sources.append({ + 'Name': r'{:9}| File-Based: [DIR] {}\{}'.format( + ticket_path['Server']['Name'], # Server + ticket_path['Source'].name, # Ticket folder + item.name, # Sub-folder + ), + 'Server': ticket_path['Server'], + 'Source': item}) + + # Check for images in folder + for subitem in os.scandir(item.path): + if REGEX_WIM_FILE.search(item.name): + # Add image to sources + try: + size = human_readable_size(item.stat().st_size) + except Exception: + size = ' ? ?' # unknown + sources.append({ + 'Disabled': bool(not is_valid_wim_file(subitem)), + 'Name': r'{:9}| Image-Based: {:>7} {}\{}\{}'.format( + ticket_path['Server']['Name'], # Server + size, # Size (duh) + ticket_path['Source'].name, # Ticket folder + item.name, # Sub-folder + subitem.name, # Image file + ), + 'Server': ticket_path['Server'], + 'Source': subitem}) + elif REGEX_WIM_FILE.search(item.name): + # Add image to sources + try: + size = human_readable_size(item.stat().st_size) + except Exception: + size = ' ? ?' # unknown + sources.append({ + 'Disabled': bool(not is_valid_wim_file(item)), + 'Name': r'{:9}| Image-Based: {:>7} {}\{}'.format( + ticket_path['Server']['Name'], # Server + size, # Size (duh) + ticket_path['Source'].name, # Ticket folder + item.name, # Image file + ), + 'Server': ticket_path['Server'], + 'Source': item}) + # Check for local sources + print_standard('Scanning for local sources...') + set_thread_error_mode(silent=True) # Prevents "No disk" popups + sys_drive = global_vars['Env']['SYSTEMDRIVE'] + for d in psutil.disk_partitions(): + if re.search(r'^{}'.format(sys_drive), d.mountpoint, re.IGNORECASE): + # Skip current OS drive + continue + if 'fixed' in d.opts: + # Skip DVD, etc + sources.append({ + 'Name': '{:9}| File-Based: [DISK] {}'.format( + ' Local', d.mountpoint), + 'Source': LocalDisk(d)}) + set_thread_error_mode(silent=False) # Return to normal + + # Build Menu + sources.sort(key=itemgetter('Name')) + actions = [{'Name': 'Quit', 'Letter': 'Q'}] + + # Select backup from sources + if len(sources) > 0: + selection = menu_select( + 'Which backup are we using?', + main_entries=sources, + action_entries=actions, + disabled_label='DAMAGED') + if selection == 'Q': + umount_backup_shares() + exit_script() + else: + selected_source = sources[int(selection)-1]['Source'] + else: + print_error('ERROR: No backups found for ticket: {}.'.format( + ticket_number)) + umount_backup_shares() + pause("Press Enter to exit...") + exit_script() + + # Done + return selected_source + +def set_thread_error_mode(silent=True): + """Disable or Enable Windows error message dialogs. + + Disable when scanning for disks to avoid popups for empty cardreaders, etc + """ + # Code borrowed from: https://stackoverflow.com/a/29075319 + kernel32 = ctypes.WinDLL('kernel32') + + if silent: + kernel32.SetThreadErrorMode(SEM_FAIL, ctypes.byref(SEM_NORMAL)) + else: + kernel32.SetThreadErrorMode(SEM_NORMAL, ctypes.byref(SEM_NORMAL)) + +def transfer_source(source_obj, dest_path, selected_items): + """Transfer, or extract, files/folders from source to destination.""" + if source_obj.is_dir(): + # Run FastCopy for each selection "group" + for group in selected_items: + try_and_print(message=group['Message'], + function=run_fast_copy, cs='Done', + items=group['Items'], + dest=group['Destination']) + else: + if REGEX_WIM_FILE.search(source_obj.name): + # Extract files from WIM + for group in selected_items: + try_and_print(message=group['Message'], + function=run_wimextract, cs='Done', + source=source_obj.path, + items=group['Items'], + dest=group['Destination']) + else: + print_error('ERROR: Unsupported image: {}'.format(source_obj.path)) + raise GenericError + +def umount_backup_shares(): + """Unnount the backup shares regardless of current status.""" + for server in BACKUP_SERVERS: + umount_network_share(server) + +def umount_network_share(server): + """Unnount a network share defined by server.""" + cmd = r'net use \\{IP}\{Share} /delete'.format(**server) + cmd = cmd.split(' ') + try: + run_program(cmd) + except Exception: + print_error(r'Failed to umount \\{Name}\{Share}.'.format(**server)) + sleep(1) + else: + print_info('Umounted {Name}'.format(**server)) + server['Mounted'] = False + +def wim_contains(source_path, file_path): + """Check if the WIM contains a file or folder.""" + _cmd = [ + global_vars['Tools']['wimlib-imagex'], 'dir', + source_path, '1', + '--path={}'.format(file_path), + '--one-file-only'] + try: + run_program(_cmd) + except subprocess.CalledProcessError: + return False + else: + return True + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/diags.py b/.bin/Scripts/functions/diags.py index 220eaff3..e6bc433f 100644 --- a/.bin/Scripts/functions/diags.py +++ b/.bin/Scripts/functions/diags.py @@ -1,114 +1,114 @@ -# Wizard Kit: Functions - Diagnostics - -from functions.common import * - -# STATIC VARIABLES -AUTORUNS_SETTINGS = { - r'Software\Sysinternals\AutoRuns': { - 'checkvirustotal': 1, - 'EulaAccepted': 1, - 'shownomicrosoft': 1, - 'shownowindows': 1, - 'showonlyvirustotal': 1, - 'submitvirustotal': 0, - 'verifysignatures': 1, - }, - r'Software\Sysinternals\AutoRuns\SigCheck': { - 'EulaAccepted': 1, - }, - r'Software\Sysinternals\AutoRuns\Streams': { - 'EulaAccepted': 1, - }, - r'Software\Sysinternals\AutoRuns\VirusTotal': { - 'VirusTotalTermsAccepted': 1, - }, - } - -def check_connection(): - """Check if the system is online and optionally abort the script.""" - while True: - result = try_and_print(message='Ping test...', function=ping, cs='OK') - if result['CS']: - break - else: - if not ask('ERROR: System appears offline, try again?'): - if ask('Continue anyway?'): - break - else: - abort() - -def run_autoruns(): - """Run AutoRuns in the background with VirusTotal checks enabled.""" - extract_item('Autoruns', filter='autoruns*', silent=True) - # Update AutoRuns settings before running - for path, settings in AUTORUNS_SETTINGS.items(): - winreg.CreateKey(HKCU, path) - with winreg.OpenKey(HKCU, path, access=winreg.KEY_WRITE) as key: - for name, value in settings.items(): - winreg.SetValueEx(key, name, 0, winreg.REG_DWORD, value) - popen_program(global_vars['Tools']['AutoRuns'], minimized=True) - -def run_hwinfo_sensors(): - """Run HWiNFO sensors.""" - path = r'{BinDir}\HWiNFO'.format(**global_vars) - for bit in [32, 64]: - # Configure - source = r'{}\general.ini'.format(path) - dest = r'{}\HWiNFO{}.ini'.format(path, bit) - shutil.copy(source, dest) - with open(dest, 'a') as f: - f.write('SensorsOnly=1\n') - f.write('SummaryOnly=0\n') - popen_program(global_vars['Tools']['HWiNFO']) - -def run_xmplay(): - """Run XMPlay to test audio.""" - extract_item('XMPlay', silent=True) - cmd = [global_vars['Tools']['XMPlay'], - r'{BinDir}\XMPlay\music.7z'.format(**global_vars)] - popen_program(cmd) - -def run_hitmanpro(): - """Run HitmanPro in the background.""" - extract_item('HitmanPro', silent=True) - cmd = [ - global_vars['Tools']['HitmanPro'], - '/quiet', '/noinstall', '/noupload', - r'/log={LogDir}\hitman.xml'.format(**global_vars)] - popen_program(cmd) - -def run_process_killer(): - """Kill most running processes skipping those in the whitelist.txt.""" - # borrowed from TronScript (reddit.com/r/TronScript) - # credit to /u/cuddlychops06 - prev_dir = os.getcwd() - extract_item('ProcessKiller', silent=True) - os.chdir(r'{BinDir}\ProcessKiller'.format(**global_vars)) - run_program(['ProcessKiller.exe', '/silent'], check=False) - os.chdir(prev_dir) - -def run_rkill(): - """Run RKill and cleanup afterwards.""" - extract_item('RKill', silent=True) - cmd = [ - global_vars['Tools']['RKill'], - '-l', r'{LogDir}\RKill.log'.format(**global_vars), - '-new_console:n', '-new_console:s33V'] - run_program(cmd, check=False) - wait_for_process('RKill') - kill_process('notepad.exe') - - # RKill cleanup - desktop_path = r'{USERPROFILE}\Desktop'.format(**global_vars['Env']) - if os.path.exists(desktop_path): - for item in os.scandir(desktop_path): - if re.search(r'^RKill', item.name, re.IGNORECASE): - dest = re.sub(r'^(.*)\.', '\1_{Date-Time}.'.format( - **global_vars), item.name) - dest = r'{ClientDir}\Info\{name}'.format( - name=dest, **global_vars) - dest = non_clobber_rename(dest) - shutil.move(item.path, dest) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Diagnostics + +from functions.common import * + +# STATIC VARIABLES +AUTORUNS_SETTINGS = { + r'Software\Sysinternals\AutoRuns': { + 'checkvirustotal': 1, + 'EulaAccepted': 1, + 'shownomicrosoft': 1, + 'shownowindows': 1, + 'showonlyvirustotal': 1, + 'submitvirustotal': 0, + 'verifysignatures': 1, + }, + r'Software\Sysinternals\AutoRuns\SigCheck': { + 'EulaAccepted': 1, + }, + r'Software\Sysinternals\AutoRuns\Streams': { + 'EulaAccepted': 1, + }, + r'Software\Sysinternals\AutoRuns\VirusTotal': { + 'VirusTotalTermsAccepted': 1, + }, + } + +def check_connection(): + """Check if the system is online and optionally abort the script.""" + while True: + result = try_and_print(message='Ping test...', function=ping, cs='OK') + if result['CS']: + break + else: + if not ask('ERROR: System appears offline, try again?'): + if ask('Continue anyway?'): + break + else: + abort() + +def run_autoruns(): + """Run AutoRuns in the background with VirusTotal checks enabled.""" + extract_item('Autoruns', filter='autoruns*', silent=True) + # Update AutoRuns settings before running + for path, settings in AUTORUNS_SETTINGS.items(): + winreg.CreateKey(HKCU, path) + with winreg.OpenKey(HKCU, path, access=winreg.KEY_WRITE) as key: + for name, value in settings.items(): + winreg.SetValueEx(key, name, 0, winreg.REG_DWORD, value) + popen_program(global_vars['Tools']['AutoRuns'], minimized=True) + +def run_hwinfo_sensors(): + """Run HWiNFO sensors.""" + path = r'{BinDir}\HWiNFO'.format(**global_vars) + for bit in [32, 64]: + # Configure + source = r'{}\general.ini'.format(path) + dest = r'{}\HWiNFO{}.ini'.format(path, bit) + shutil.copy(source, dest) + with open(dest, 'a') as f: + f.write('SensorsOnly=1\n') + f.write('SummaryOnly=0\n') + popen_program(global_vars['Tools']['HWiNFO']) + +def run_xmplay(): + """Run XMPlay to test audio.""" + extract_item('XMPlay', silent=True) + cmd = [global_vars['Tools']['XMPlay'], + r'{BinDir}\XMPlay\music.7z'.format(**global_vars)] + popen_program(cmd) + +def run_hitmanpro(): + """Run HitmanPro in the background.""" + extract_item('HitmanPro', silent=True) + cmd = [ + global_vars['Tools']['HitmanPro'], + '/quiet', '/noinstall', '/noupload', + r'/log={LogDir}\hitman.xml'.format(**global_vars)] + popen_program(cmd) + +def run_process_killer(): + """Kill most running processes skipping those in the whitelist.txt.""" + # borrowed from TronScript (reddit.com/r/TronScript) + # credit to /u/cuddlychops06 + prev_dir = os.getcwd() + extract_item('ProcessKiller', silent=True) + os.chdir(r'{BinDir}\ProcessKiller'.format(**global_vars)) + run_program(['ProcessKiller.exe', '/silent'], check=False) + os.chdir(prev_dir) + +def run_rkill(): + """Run RKill and cleanup afterwards.""" + extract_item('RKill', silent=True) + cmd = [ + global_vars['Tools']['RKill'], + '-l', r'{LogDir}\RKill.log'.format(**global_vars), + '-new_console:n', '-new_console:s33V'] + run_program(cmd, check=False) + wait_for_process('RKill') + kill_process('notepad.exe') + + # RKill cleanup + desktop_path = r'{USERPROFILE}\Desktop'.format(**global_vars['Env']) + if os.path.exists(desktop_path): + for item in os.scandir(desktop_path): + if re.search(r'^RKill', item.name, re.IGNORECASE): + dest = re.sub(r'^(.*)\.', '\1_{Date-Time}.'.format( + **global_vars), item.name) + dest = r'{ClientDir}\Info\{name}'.format( + name=dest, **global_vars) + dest = non_clobber_rename(dest) + shutil.move(item.path, dest) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/info.py b/.bin/Scripts/functions/info.py index eb2c7089..5ce703f3 100644 --- a/.bin/Scripts/functions/info.py +++ b/.bin/Scripts/functions/info.py @@ -1,465 +1,465 @@ -# Wizard Kit: Functions - Information - -from borrowed import knownpaths -from operator import itemgetter - -from functions.common import * -from functions.activation import * - -# Regex -REGEX_OFFICE = re.compile( - r'(Microsoft (Office\s+' - r'(365|Enterprise|Home|Pro(\s|fessional)' - r'|Single|Small|Standard|Starter|Ultimate|system)' - r'|Works[-\s\d]+\d)' - r'|(Libre|Open|Star)\s*Office' - r'|WordPerfect|Gnumeric|Abiword)', - re.IGNORECASE) - -# STATIC VARIABLES -REG_PROFILE_LIST = r'SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList' -REG_SHELL_FOLDERS = r'Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders' -TMP_HIVE_PATH = 'TEMP_HIVE_MOUNT' -EXTRA_FOLDERS = [ - 'Dropbox', - 'Google Drive', - 'OneDrive', - 'SkyDrive', -] -SHELL_FOLDERS = { - #GUIDs from: https://msdn.microsoft.com/en-us/library/windows/desktop/dd378457(v=vs.85).aspx - 'Desktop': ( - '{B4BFCC3A-DB2C-424C-B029-7FE99A87C641}', - ), - 'Documents': ( - 'Personal', - '{FDD39AD0-238F-46AF-ADB4-6C85480369C7}', - ), - 'Downloads': ( - '{374DE290-123F-4565-9164-39C4925E467B}', - ), - 'Favorites': ( - '{1777F761-68AD-4D8A-87BD-30B759FA33DD}', - ), - 'Music': ( - 'My Music', - '{4BD8D571-6D19-48D3-BE97-422220080E43}', - ), - 'Pictures': ( - 'My Pictures', - '{33E28130-4E1E-4676-835A-98395C3BC3BB}', - ), - 'Videos': ( - 'My Video', - '{18989B1D-99B5-455B-841C-AB7C74E4DDFC}', - ), -} - -def backup_file_list(): - """Export current file listing for the system.""" - extract_item('Everything', silent=True) - cmd = [ - global_vars['Tools']['Everything'], - '-nodb', - '-create-filelist', - r'{LogDir}\File List.txt'.format(**global_vars), - global_vars['Env']['SYSTEMDRIVE']] - run_program(cmd) - -def backup_power_plans(): - """Export current power plans.""" - os.makedirs(r'{BackupDir}\Power Plans'.format(**global_vars), exist_ok=True) - plans = run_program(['powercfg', '/L']) - plans = plans.stdout.decode().splitlines() - plans = [p for p in plans if re.search(r'^Power Scheme', p)] - for p in plans: - guid = re.sub(r'Power Scheme GUID:\s+([0-9a-f\-]+).*', r'\1', p) - name = re.sub( - r'Power Scheme GUID:\s+[0-9a-f\-]+\s+\(([^\)]+)\).*', r'\1', p) - out = r'{BackupDir}\Power Plans\{name}.pow'.format( - name=name, **global_vars) - if not os.path.exists(out): - cmd = ['powercfg', '-export', out, guid] - run_program(cmd, check=False) - -def backup_registry(): - """Backup registry including user hives.""" - extract_item('erunt', silent=True) - cmd = [ - global_vars['Tools']['ERUNT'], - r'{LogDir}\Registry'.format(**global_vars), - 'sysreg', - 'curuser', - 'otherusers', - '/noprogresswindow'] - run_program(cmd) - -def get_folder_size(path): - """Get (human-readable) size of folder passed, returns str.""" - size = 'Unknown' - cmd = [global_vars['Tools']['Du'], '-nobanner', '-q', path] - try: - out = run_program(cmd) - except FileNotFoundError: - # Failed to find folder - pass - except subprocess.CalledProcessError: - # Failed to get folder size - pass - else: - size = out.stdout.decode().splitlines()[4] - size = re.sub(r'Size:\s+([\d,]+)\sbytes$', r'\1', size) - size = size.replace(',', '') - size = human_readable_size(size) - return size - -def get_installed_office(): - """Get list of installed Office programs.""" - programs = [] - log_file = r'{LogDir}\Installed Program List (AIDA64).txt'.format( - **global_vars) - with open (log_file, 'r') as f: - for line in sorted(f.readlines()): - if REGEX_OFFICE.search(line): - programs.append(line[4:82].strip()) - - if len(programs) == 0: - programs = ['No programs found'] - return programs - -def get_shell_path(folder, user='current'): - """Get shell path using SHGetKnownFolderPath via knownpaths, returns str. - - NOTE: Only works for the current user. - Code based on https://gist.github.com/mkropat/7550097 - """ - path = None - folderid = None - if user.lower() == 'public': - user = 'common' - try: - folderid = getattr(knownpaths.FOLDERID, folder) - except AttributeError: - # Unknown folder ID, ignore and return None - pass - - if folderid: - try: - path = knownpaths.get_path(folderid, getattr(knownpaths.UserHandle, user)) - except PathNotFoundException: - # Folder not found, ignore and return None - pass - - return path - -def get_user_data_paths(user): - """Get user data paths for provided user, returns dict.""" - hive_path = user['SID'] - paths = { - 'Profile': { - 'Path': None, - }, - 'Shell Folders': {}, - 'Extra Folders': {}, - } - unload_hive = False - - if user['Name'] == global_vars['Env']['USERNAME']: - # We can use SHGetKnownFolderPath for the current user - paths['Profile']['Path'] = get_shell_path('Profile') - paths['Shell Folders'] = {f: {'Path': get_shell_path(f)} - for f in SHELL_FOLDERS.keys()} - else: - # We have to use the NTUSER.dat hives which isn't recommended by MS - try: - key_path = r'{}\{}'.format(REG_PROFILE_LIST, user['SID']) - with winreg.OpenKey(HKLM, key_path) as key: - paths['Profile']['Path'] = winreg.QueryValueEx( - key, 'ProfileImagePath')[0] - except Exception: - # Profile path not found, leaving as None. - pass - - # Shell folders (Prep) - if not reg_path_exists(HKU, hive_path) and paths['Profile']['Path']: - # User not logged-in, loading hive - # Also setting unload_hive so it will be unloaded later. - hive_path = TMP_HIVE_PATH - cmd = ['reg', 'load', r'HKU\{}'.format(TMP_HIVE_PATH), - r'{}\NTUSER.DAT'.format(paths['Profile']['Path'])] - unload_hive = True - try: - run_program(cmd) - except subprocess.CalledProcessError: - # Failed to load user hive - pass - - # Shell folders - shell_folders = r'{}\{}'.format(hive_path, REG_SHELL_FOLDERS) - if (reg_path_exists(HKU, hive_path) - and reg_path_exists(HKU, shell_folders)): - with winreg.OpenKey(HKU, shell_folders) as key: - for folder, values in SHELL_FOLDERS.items(): - for value in values: - try: - path = winreg.QueryValueEx(key, value)[0] - except FileNotFoundError: - # Skip missing values - pass - else: - paths['Shell Folders'][folder] = {'Path': path} - # Stop checking values for this folder - break - - # Shell folder (extra check) - if paths['Profile']['Path']: - for folder in SHELL_FOLDERS.keys(): - folder_path = r'{Path}\{folder}'.format( - folder=folder, **paths['Profile']) - if (folder not in paths['Shell Folders'] - and os.path.exists(folder_path)): - paths['Shell Folders'][folder] = {'Path': folder_path} - - # Extra folders - if paths['Profile']['Path']: - for folder in EXTRA_FOLDERS: - folder_path = r'{Path}\{folder}'.format( - folder=folder, **paths['Profile']) - if os.path.exists(folder_path): - paths['Extra Folders'][folder] = {'Path': folder_path} - - # Shell folders (cleanup) - if unload_hive: - cmd = ['reg', 'unload', r'HKU\{}'.format(TMP_HIVE_PATH)] - run_program(cmd, check=False) - - # Done - return paths - -def get_user_folder_sizes(users): - """Update list(users) to include folder paths and sizes.""" - extract_item('du', filter='du*', silent=True) - # Configure Du - winreg.CreateKey(HKCU, r'Software\Sysinternals\Du') - with winreg.OpenKey(HKCU, - r'Software\Sysinternals\Du', access=winreg.KEY_WRITE) as key: - winreg.SetValueEx(key, 'EulaAccepted', 0, winreg.REG_DWORD, 1) - - for u in users: - u.update(get_user_data_paths(u)) - if u['Profile']['Path']: - u['Profile']['Size'] = get_folder_size(u['Profile']['Path']) - for folder in u['Shell Folders'].keys(): - u['Shell Folders'][folder]['Size'] = get_folder_size( - u['Shell Folders'][folder]['Path']) - for folder in u['Extra Folders'].keys(): - u['Extra Folders'][folder]['Size'] = get_folder_size( - u['Extra Folders'][folder]['Path']) - -def get_user_list(): - """Get user list via WMIC, returns list of dicts.""" - users = [] - - # Get user info from WMI - cmd = ['wmic', 'useraccount', 'get', '/format:csv'] - try: - out = run_program(cmd) - except subprocess.CalledProcessError: - # Meh, return empty list to avoid a full crash - return users - - entries = out.stdout.decode().splitlines() - entries = [e.strip().split(',') for e in entries if e.strip()] - - # Add user(s) to dict - keys = entries[0] - for e in entries[1:]: - # Create dict using 1st line (keys) - e = dict(zip(keys, e)) - # Set Active status via 'Disabled' TRUE/FALSE str - e['Active'] = bool(e['Disabled'].upper() == 'FALSE') - # Assume SIDs ending with 1000+ are "Standard" and others are "System" - e['Type'] = 'Standard' if re.search(r'-1\d+$', e['SID']) else 'System' - users.append(e) - - # Sort list - users.sort(key=itemgetter('Name')) - - # Done - return users - -def reg_path_exists(hive, path): - """Test if specified path exists, returns bool.""" - try: - winreg.QueryValue(hive, path) - except FileNotFoundError: - return False - else: - return True - -def run_aida64(): - """Run AIDA64 to save system reports.""" - extract_item('AIDA64', silent=True) - # All system info - config = r'{BinDir}\AIDA64\full.rpf'.format(**global_vars) - report_file = r'{LogDir}\System Information (AIDA64).html'.format( - **global_vars) - if not os.path.exists(report_file): - cmd = [ - global_vars['Tools']['AIDA64'], - '/R', report_file, - '/CUSTOM', config, - '/HTML', '/SILENT', '/SAFEST'] - run_program(cmd, check=False) - - # Installed Programs - config = r'{BinDir}\AIDA64\installed_programs.rpf'.format(**global_vars) - report_file = r'{LogDir}\Installed Program List (AIDA64).txt'.format( - **global_vars) - if not os.path.exists(report_file): - cmd = [ - global_vars['Tools']['AIDA64'], - '/R', report_file, - '/CUSTOM', config, - '/TEXT', '/SILENT', '/SAFEST'] - run_program(cmd, check=False) - - # Product Keys - config = r'{BinDir}\AIDA64\licenses.rpf'.format(**global_vars) - report_file = r'{LogDir}\Product Keys (AIDA64).txt'.format(**global_vars) - if not os.path.exists(report_file): - cmd = [ - global_vars['Tools']['AIDA64'], - '/R', report_file, - '/CUSTOM', config, - '/TEXT', '/SILENT', '/SAFEST'] - run_program(cmd, check=False) - -def run_bleachbit(): - """Run BleachBit preview and save log. - - This is a preview so no files should be deleted.""" - if not os.path.exists(global_vars['LogDir']+r'\BleachBit.log'): - extract_item('BleachBit', silent=True) - cmd = [global_vars['Tools']['BleachBit'], '--preview', '--preset'] - out = run_program(cmd, check=False) - # Save stderr - if out.stderr.decode().splitlines(): - with open(global_vars['LogDir']+r'\BleachBit.err', 'a') as f: - for line in out.stderr.decode().splitlines(): - f.write(line.strip() + '\n') - # Save stdout - with open(global_vars['LogDir']+r'\BleachBit.log', 'a') as f: - for line in out.stdout.decode().splitlines(): - f.write(line.strip() + '\n') - -def show_disk_usage(disk): - """Show free and used space for a specified disk.""" - print_standard('{:5}'.format(disk.device.replace('/', ' ')), - end='', flush=True, timestamp=False) - try: - usage = psutil.disk_usage(disk.device) - display_string = '{percent:>5.2f}% Free ({free} / {total})'.format( - percent = 100 - usage.percent, - free = human_readable_size(usage.free, 2), - total = human_readable_size(usage.total, 2)) - if usage.percent > 85: - print_error(display_string, timestamp=False) - elif usage.percent > 75: - print_warning(display_string, timestamp=False) - else: - print_standard(display_string, timestamp=False) - except Exception: - print_warning('Unknown', timestamp=False) - -def show_free_space(indent=8, width=32): - """Show free space info for all fixed disks.""" - message = 'Free Space:' - for disk in psutil.disk_partitions(): - try: - if 'fixed' in disk.opts: - try_and_print(message=message, function=show_disk_usage, - ns='Unknown', silent_function=False, - indent=indent, width=width, disk=disk) - message = '' - except Exception: - pass - -def show_installed_ram(): - """Show installed RAM.""" - mem = psutil.virtual_memory() - if mem.total > 5905580032: - # > 5.5 Gb so 6Gb or greater - print_standard(human_readable_size(mem.total).strip()) - elif mem.total > 3758096384: - # > 3.5 Gb so 4Gb or greater - print_warning(human_readable_size(mem.total).strip()) - else: - print_error(human_readable_size(mem.total).strip()) - -def show_os_activation(): - """Show OS activation info.""" - act_str = get_activation_string() - if windows_is_activated(): - print_standard(act_str, timestamp=False) - elif re.search(r'unavailable', act_str, re.IGNORECASE): - print_warning(act_str, timestamp=False) - else: - print_error(act_str, timestamp=False) - -def show_os_name(): - """Show extended OS name (including warnings).""" - os_name = global_vars['OS']['DisplayName'] - if global_vars['OS']['Arch'] == 32: - # Show all 32-bit installs as an error message - print_error(os_name, timestamp=False) - else: - if re.search(r'(unrecognized|very outdated)', os_name, re.IGNORECASE): - print_error(os_name, timestamp=False) - elif re.search(r'outdated', os_name, re.IGNORECASE): - print_warning(os_name, timestamp=False) - else: - print_standard(os_name, timestamp=False) - -def show_temp_files_size(): - """Show total size of temp files identified by BleachBit.""" - size = None - with open(r'{LogDir}\BleachBit.log'.format(**global_vars), 'r') as f: - for line in f.readlines(): - if re.search(r'^disk space to be recovered:', line, re.IGNORECASE): - size = re.sub(r'.*: ', '', line.strip()) - size = re.sub(r'(\w)iB$', r' \1b', size) - if size is None: - print_warning(size, timestamp=False) - else: - print_standard(size, timestamp=False) - -def show_user_data_summary(indent=8, width=32): - """Print user data folder sizes for all users.""" - users = get_user_list() - users = [u for u in users if u['Active']] - get_user_folder_sizes(users) - for user in users: - print_success('{indent}User: {user}'.format( - indent = ' '*int(indent/2), - user = user['Name'])) - for section in ['Profile', None, 'Shell Folders', 'Extra Folders']: - folders = [] - if section is None: - # Divider - print_standard('{}{}'.format(' '*indent, '-'*(width+6))) - elif section == 'Profile': - folders = {'Profile': user['Profile']} - else: - folders = user[section] - for folder in folders: - print_standard( - '{indent}{folder:<{width}}{size:>6} ({path})'.format( - indent = ' ' * indent, - width = width, - folder = folder, - size = folders[folder]['Size'], - path = folders[folder]['Path'])) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Information + +from borrowed import knownpaths +from operator import itemgetter + +from functions.common import * +from functions.activation import * + +# Regex +REGEX_OFFICE = re.compile( + r'(Microsoft (Office\s+' + r'(365|Enterprise|Home|Pro(\s|fessional)' + r'|Single|Small|Standard|Starter|Ultimate|system)' + r'|Works[-\s\d]+\d)' + r'|(Libre|Open|Star)\s*Office' + r'|WordPerfect|Gnumeric|Abiword)', + re.IGNORECASE) + +# STATIC VARIABLES +REG_PROFILE_LIST = r'SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList' +REG_SHELL_FOLDERS = r'Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders' +TMP_HIVE_PATH = 'TEMP_HIVE_MOUNT' +EXTRA_FOLDERS = [ + 'Dropbox', + 'Google Drive', + 'OneDrive', + 'SkyDrive', +] +SHELL_FOLDERS = { + #GUIDs from: https://msdn.microsoft.com/en-us/library/windows/desktop/dd378457(v=vs.85).aspx + 'Desktop': ( + '{B4BFCC3A-DB2C-424C-B029-7FE99A87C641}', + ), + 'Documents': ( + 'Personal', + '{FDD39AD0-238F-46AF-ADB4-6C85480369C7}', + ), + 'Downloads': ( + '{374DE290-123F-4565-9164-39C4925E467B}', + ), + 'Favorites': ( + '{1777F761-68AD-4D8A-87BD-30B759FA33DD}', + ), + 'Music': ( + 'My Music', + '{4BD8D571-6D19-48D3-BE97-422220080E43}', + ), + 'Pictures': ( + 'My Pictures', + '{33E28130-4E1E-4676-835A-98395C3BC3BB}', + ), + 'Videos': ( + 'My Video', + '{18989B1D-99B5-455B-841C-AB7C74E4DDFC}', + ), +} + +def backup_file_list(): + """Export current file listing for the system.""" + extract_item('Everything', silent=True) + cmd = [ + global_vars['Tools']['Everything'], + '-nodb', + '-create-filelist', + r'{LogDir}\File List.txt'.format(**global_vars), + global_vars['Env']['SYSTEMDRIVE']] + run_program(cmd) + +def backup_power_plans(): + """Export current power plans.""" + os.makedirs(r'{BackupDir}\Power Plans'.format(**global_vars), exist_ok=True) + plans = run_program(['powercfg', '/L']) + plans = plans.stdout.decode().splitlines() + plans = [p for p in plans if re.search(r'^Power Scheme', p)] + for p in plans: + guid = re.sub(r'Power Scheme GUID:\s+([0-9a-f\-]+).*', r'\1', p) + name = re.sub( + r'Power Scheme GUID:\s+[0-9a-f\-]+\s+\(([^\)]+)\).*', r'\1', p) + out = r'{BackupDir}\Power Plans\{name}.pow'.format( + name=name, **global_vars) + if not os.path.exists(out): + cmd = ['powercfg', '-export', out, guid] + run_program(cmd, check=False) + +def backup_registry(): + """Backup registry including user hives.""" + extract_item('erunt', silent=True) + cmd = [ + global_vars['Tools']['ERUNT'], + r'{LogDir}\Registry'.format(**global_vars), + 'sysreg', + 'curuser', + 'otherusers', + '/noprogresswindow'] + run_program(cmd) + +def get_folder_size(path): + """Get (human-readable) size of folder passed, returns str.""" + size = 'Unknown' + cmd = [global_vars['Tools']['Du'], '-nobanner', '-q', path] + try: + out = run_program(cmd) + except FileNotFoundError: + # Failed to find folder + pass + except subprocess.CalledProcessError: + # Failed to get folder size + pass + else: + size = out.stdout.decode().splitlines()[4] + size = re.sub(r'Size:\s+([\d,]+)\sbytes$', r'\1', size) + size = size.replace(',', '') + size = human_readable_size(size) + return size + +def get_installed_office(): + """Get list of installed Office programs.""" + programs = [] + log_file = r'{LogDir}\Installed Program List (AIDA64).txt'.format( + **global_vars) + with open (log_file, 'r') as f: + for line in sorted(f.readlines()): + if REGEX_OFFICE.search(line): + programs.append(line[4:82].strip()) + + if len(programs) == 0: + programs = ['No programs found'] + return programs + +def get_shell_path(folder, user='current'): + """Get shell path using SHGetKnownFolderPath via knownpaths, returns str. + + NOTE: Only works for the current user. + Code based on https://gist.github.com/mkropat/7550097 + """ + path = None + folderid = None + if user.lower() == 'public': + user = 'common' + try: + folderid = getattr(knownpaths.FOLDERID, folder) + except AttributeError: + # Unknown folder ID, ignore and return None + pass + + if folderid: + try: + path = knownpaths.get_path(folderid, getattr(knownpaths.UserHandle, user)) + except PathNotFoundException: + # Folder not found, ignore and return None + pass + + return path + +def get_user_data_paths(user): + """Get user data paths for provided user, returns dict.""" + hive_path = user['SID'] + paths = { + 'Profile': { + 'Path': None, + }, + 'Shell Folders': {}, + 'Extra Folders': {}, + } + unload_hive = False + + if user['Name'] == global_vars['Env']['USERNAME']: + # We can use SHGetKnownFolderPath for the current user + paths['Profile']['Path'] = get_shell_path('Profile') + paths['Shell Folders'] = {f: {'Path': get_shell_path(f)} + for f in SHELL_FOLDERS.keys()} + else: + # We have to use the NTUSER.dat hives which isn't recommended by MS + try: + key_path = r'{}\{}'.format(REG_PROFILE_LIST, user['SID']) + with winreg.OpenKey(HKLM, key_path) as key: + paths['Profile']['Path'] = winreg.QueryValueEx( + key, 'ProfileImagePath')[0] + except Exception: + # Profile path not found, leaving as None. + pass + + # Shell folders (Prep) + if not reg_path_exists(HKU, hive_path) and paths['Profile']['Path']: + # User not logged-in, loading hive + # Also setting unload_hive so it will be unloaded later. + hive_path = TMP_HIVE_PATH + cmd = ['reg', 'load', r'HKU\{}'.format(TMP_HIVE_PATH), + r'{}\NTUSER.DAT'.format(paths['Profile']['Path'])] + unload_hive = True + try: + run_program(cmd) + except subprocess.CalledProcessError: + # Failed to load user hive + pass + + # Shell folders + shell_folders = r'{}\{}'.format(hive_path, REG_SHELL_FOLDERS) + if (reg_path_exists(HKU, hive_path) + and reg_path_exists(HKU, shell_folders)): + with winreg.OpenKey(HKU, shell_folders) as key: + for folder, values in SHELL_FOLDERS.items(): + for value in values: + try: + path = winreg.QueryValueEx(key, value)[0] + except FileNotFoundError: + # Skip missing values + pass + else: + paths['Shell Folders'][folder] = {'Path': path} + # Stop checking values for this folder + break + + # Shell folder (extra check) + if paths['Profile']['Path']: + for folder in SHELL_FOLDERS.keys(): + folder_path = r'{Path}\{folder}'.format( + folder=folder, **paths['Profile']) + if (folder not in paths['Shell Folders'] + and os.path.exists(folder_path)): + paths['Shell Folders'][folder] = {'Path': folder_path} + + # Extra folders + if paths['Profile']['Path']: + for folder in EXTRA_FOLDERS: + folder_path = r'{Path}\{folder}'.format( + folder=folder, **paths['Profile']) + if os.path.exists(folder_path): + paths['Extra Folders'][folder] = {'Path': folder_path} + + # Shell folders (cleanup) + if unload_hive: + cmd = ['reg', 'unload', r'HKU\{}'.format(TMP_HIVE_PATH)] + run_program(cmd, check=False) + + # Done + return paths + +def get_user_folder_sizes(users): + """Update list(users) to include folder paths and sizes.""" + extract_item('du', filter='du*', silent=True) + # Configure Du + winreg.CreateKey(HKCU, r'Software\Sysinternals\Du') + with winreg.OpenKey(HKCU, + r'Software\Sysinternals\Du', access=winreg.KEY_WRITE) as key: + winreg.SetValueEx(key, 'EulaAccepted', 0, winreg.REG_DWORD, 1) + + for u in users: + u.update(get_user_data_paths(u)) + if u['Profile']['Path']: + u['Profile']['Size'] = get_folder_size(u['Profile']['Path']) + for folder in u['Shell Folders'].keys(): + u['Shell Folders'][folder]['Size'] = get_folder_size( + u['Shell Folders'][folder]['Path']) + for folder in u['Extra Folders'].keys(): + u['Extra Folders'][folder]['Size'] = get_folder_size( + u['Extra Folders'][folder]['Path']) + +def get_user_list(): + """Get user list via WMIC, returns list of dicts.""" + users = [] + + # Get user info from WMI + cmd = ['wmic', 'useraccount', 'get', '/format:csv'] + try: + out = run_program(cmd) + except subprocess.CalledProcessError: + # Meh, return empty list to avoid a full crash + return users + + entries = out.stdout.decode().splitlines() + entries = [e.strip().split(',') for e in entries if e.strip()] + + # Add user(s) to dict + keys = entries[0] + for e in entries[1:]: + # Create dict using 1st line (keys) + e = dict(zip(keys, e)) + # Set Active status via 'Disabled' TRUE/FALSE str + e['Active'] = bool(e['Disabled'].upper() == 'FALSE') + # Assume SIDs ending with 1000+ are "Standard" and others are "System" + e['Type'] = 'Standard' if re.search(r'-1\d+$', e['SID']) else 'System' + users.append(e) + + # Sort list + users.sort(key=itemgetter('Name')) + + # Done + return users + +def reg_path_exists(hive, path): + """Test if specified path exists, returns bool.""" + try: + winreg.QueryValue(hive, path) + except FileNotFoundError: + return False + else: + return True + +def run_aida64(): + """Run AIDA64 to save system reports.""" + extract_item('AIDA64', silent=True) + # All system info + config = r'{BinDir}\AIDA64\full.rpf'.format(**global_vars) + report_file = r'{LogDir}\System Information (AIDA64).html'.format( + **global_vars) + if not os.path.exists(report_file): + cmd = [ + global_vars['Tools']['AIDA64'], + '/R', report_file, + '/CUSTOM', config, + '/HTML', '/SILENT', '/SAFEST'] + run_program(cmd, check=False) + + # Installed Programs + config = r'{BinDir}\AIDA64\installed_programs.rpf'.format(**global_vars) + report_file = r'{LogDir}\Installed Program List (AIDA64).txt'.format( + **global_vars) + if not os.path.exists(report_file): + cmd = [ + global_vars['Tools']['AIDA64'], + '/R', report_file, + '/CUSTOM', config, + '/TEXT', '/SILENT', '/SAFEST'] + run_program(cmd, check=False) + + # Product Keys + config = r'{BinDir}\AIDA64\licenses.rpf'.format(**global_vars) + report_file = r'{LogDir}\Product Keys (AIDA64).txt'.format(**global_vars) + if not os.path.exists(report_file): + cmd = [ + global_vars['Tools']['AIDA64'], + '/R', report_file, + '/CUSTOM', config, + '/TEXT', '/SILENT', '/SAFEST'] + run_program(cmd, check=False) + +def run_bleachbit(): + """Run BleachBit preview and save log. + + This is a preview so no files should be deleted.""" + if not os.path.exists(global_vars['LogDir']+r'\BleachBit.log'): + extract_item('BleachBit', silent=True) + cmd = [global_vars['Tools']['BleachBit'], '--preview', '--preset'] + out = run_program(cmd, check=False) + # Save stderr + if out.stderr.decode().splitlines(): + with open(global_vars['LogDir']+r'\BleachBit.err', 'a') as f: + for line in out.stderr.decode().splitlines(): + f.write(line.strip() + '\n') + # Save stdout + with open(global_vars['LogDir']+r'\BleachBit.log', 'a') as f: + for line in out.stdout.decode().splitlines(): + f.write(line.strip() + '\n') + +def show_disk_usage(disk): + """Show free and used space for a specified disk.""" + print_standard('{:5}'.format(disk.device.replace('/', ' ')), + end='', flush=True, timestamp=False) + try: + usage = psutil.disk_usage(disk.device) + display_string = '{percent:>5.2f}% Free ({free} / {total})'.format( + percent = 100 - usage.percent, + free = human_readable_size(usage.free, 2), + total = human_readable_size(usage.total, 2)) + if usage.percent > 85: + print_error(display_string, timestamp=False) + elif usage.percent > 75: + print_warning(display_string, timestamp=False) + else: + print_standard(display_string, timestamp=False) + except Exception: + print_warning('Unknown', timestamp=False) + +def show_free_space(indent=8, width=32): + """Show free space info for all fixed disks.""" + message = 'Free Space:' + for disk in psutil.disk_partitions(): + try: + if 'fixed' in disk.opts: + try_and_print(message=message, function=show_disk_usage, + ns='Unknown', silent_function=False, + indent=indent, width=width, disk=disk) + message = '' + except Exception: + pass + +def show_installed_ram(): + """Show installed RAM.""" + mem = psutil.virtual_memory() + if mem.total > 5905580032: + # > 5.5 Gb so 6Gb or greater + print_standard(human_readable_size(mem.total).strip()) + elif mem.total > 3758096384: + # > 3.5 Gb so 4Gb or greater + print_warning(human_readable_size(mem.total).strip()) + else: + print_error(human_readable_size(mem.total).strip()) + +def show_os_activation(): + """Show OS activation info.""" + act_str = get_activation_string() + if windows_is_activated(): + print_standard(act_str, timestamp=False) + elif re.search(r'unavailable', act_str, re.IGNORECASE): + print_warning(act_str, timestamp=False) + else: + print_error(act_str, timestamp=False) + +def show_os_name(): + """Show extended OS name (including warnings).""" + os_name = global_vars['OS']['DisplayName'] + if global_vars['OS']['Arch'] == 32: + # Show all 32-bit installs as an error message + print_error(os_name, timestamp=False) + else: + if re.search(r'(unrecognized|very outdated)', os_name, re.IGNORECASE): + print_error(os_name, timestamp=False) + elif re.search(r'outdated', os_name, re.IGNORECASE): + print_warning(os_name, timestamp=False) + else: + print_standard(os_name, timestamp=False) + +def show_temp_files_size(): + """Show total size of temp files identified by BleachBit.""" + size = None + with open(r'{LogDir}\BleachBit.log'.format(**global_vars), 'r') as f: + for line in f.readlines(): + if re.search(r'^disk space to be recovered:', line, re.IGNORECASE): + size = re.sub(r'.*: ', '', line.strip()) + size = re.sub(r'(\w)iB$', r' \1b', size) + if size is None: + print_warning(size, timestamp=False) + else: + print_standard(size, timestamp=False) + +def show_user_data_summary(indent=8, width=32): + """Print user data folder sizes for all users.""" + users = get_user_list() + users = [u for u in users if u['Active']] + get_user_folder_sizes(users) + for user in users: + print_success('{indent}User: {user}'.format( + indent = ' '*int(indent/2), + user = user['Name'])) + for section in ['Profile', None, 'Shell Folders', 'Extra Folders']: + folders = [] + if section is None: + # Divider + print_standard('{}{}'.format(' '*indent, '-'*(width+6))) + elif section == 'Profile': + folders = {'Profile': user['Profile']} + else: + folders = user[section] + for folder in folders: + print_standard( + '{indent}{folder:<{width}}{size:>6} ({path})'.format( + indent = ' ' * indent, + width = width, + folder = folder, + size = folders[folder]['Size'], + path = folders[folder]['Path'])) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/partition_uids.py b/.bin/Scripts/functions/partition_uids.py index 92d1c0d1..51e8387a 100644 --- a/.bin/Scripts/functions/partition_uids.py +++ b/.bin/Scripts/functions/partition_uids.py @@ -1,325 +1,325 @@ -# Wizard Kit: Functions - PARTITION UIDs -# sources: https://en.wikipedia.org/wiki/GUID_Partition_Table -# https://en.wikipedia.org/wiki/Partition_type - -PARTITION_UIDS = { - '00': {'OS': 'All', 'Description': 'Empty partition entry'}, - '01': {'OS': 'DOS 2.0+', 'Description': 'FAT12 as primary partition in first physical 32 MB of disk or as logical drive anywhere on disk (else use 06hinstead)'}, - '02': {'OS': 'XENIX', 'Description': 'XENIX root'}, - '03': {'OS': 'XENIX', 'Description': 'XENIX usr'}, - '04': {'OS': 'DOS 3.0+', 'Description': 'FAT16 with less than 65536 sectors (32 MB). As primary partition it must reside in first physical 32 MB of disk, or as logical drive anywhere on disk (else use 06h instead).'}, - '05': {'OS': 'DOS (3.2) 3.3+ / SpeedStor', 'Description': 'Extended partition with CHS addressing. It must reside in first physical 8 GB of disk, else use 0Fh instead / can occur in SpeedStor MBRs'}, - '06': {'OS': 'DOS 3.31+', 'Description': 'FAT16B with 65536 or more sectors. It must reside in first physical 8 GB of disk, unless used for logical drives in an 0Fh extended partition (else use 0Eh instead). Also used for FAT12 and FAT16 volumes in primary partitions if they are not residing in first physical 32 MB of disk.'}, - '07': {'OS': 'OS/2 1.2+ / OS/2 1.2+, Windows NT / Windows NT / Windows Embedded CE / QNX 2', 'Description': 'IFS / HPFS / NTFS / exFAT / QNX "qnx" (7) (pre-1988 only)'}, - '08': {'OS': 'Commodore MS-DOS 3.x / OS/2 1.0-1.3 / AIX / QNX 1.x/2.x', 'Description': 'Logical sectored FAT12 or FAT16 / OS/2 (FAT?) / AIX boot/split / SplitDrive / QNX "qny" (8) / partition spanning multiple drives'}, - '09': {'OS': 'AIX / QNX 1.x/2.x / Coherent / OS-9', 'Description': 'AIX data/boot / QNX "qnz" (9) / Coherent file system / OS-9 RBF'}, - '0A': {'OS': 'OS/2 / Coherent', 'Description': 'OS/2 Boot Manager / Coherent swap partition'}, - '0B': {'OS': 'DOS 7.1+', 'Description': 'FAT32 with CHS addressing'}, - '0C': {'OS': 'DOS 7.1+', 'Description': 'FAT32 with LBA'}, - '0D': {'OS': 'Silicon Safe', 'Description': 'Reserved'}, - '0E': {'OS': 'DOS 7.0+', 'Description': 'FAT16B with LBA'}, - '0F': {'OS': 'DOS 7.0+', 'Description': 'Extended partition with LBA'}, - '10': {'OS': 'OPUS', 'Description': 'Unknown'}, - '11': {'OS': 'Leading Edge MS-DOS 3.x / OS/2 Boot Manager', 'Description': 'Logical sectored FAT12 or FAT16 / Hidden FAT12 '}, - '12': {'OS': 'Compaq Contura', 'Description': 'configuration partition (bootable FAT) / configuration partition / hibernation partition / diagnostics and firmware partition (bootable FAT) / service partition (bootable FAT) / Rescue and Recovery partition'}, - '14': {'OS': 'AST MS-DOS 3.x / OS/2 Boot Manager / Maverick OS', 'Description': 'Logical sectored FAT12 or FAT16 / Hidden FAT16 / Omega file system'}, - '15': {'OS': 'OS/2 Boot Manager / Maverick OS', 'Description': 'Hidden extended partition with CHS addressing / swap'}, - '16': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT16B '}, - '17': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden IFS / Hidden HPFS / Hidden NTFS / Hidden exFAT '}, - '18': {'OS': 'AST Windows', 'Description': 'AST Zero Volt Suspend or SmartSleep partition'}, - '19': {'OS': 'Willowtech Photon coS', 'Description': 'Willowtech Photon coS'}, - '1B': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT32 '}, - '1C': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT32 with LBA '}, - '1E': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT16 with LBA '}, - '1F': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden extended partition with LBA addressing '}, - '20': {'OS': 'Windows Mobile', 'Description': 'Windows Mobile update XIP / Willowsoft Overture File System (OFS1)'}, - '21': {'OS': 'Oxygen', 'Description': 'HP Volume Expansion (SpeedStor) / FSo2 (Oxygen File System)'}, - '22': {'OS': 'Oxygen', 'Description': 'Oxygen Extended Partition Table'}, - '23': {'OS': 'Windows Mobile', 'Description': 'Reserved / Windows Mobile boot XIP'}, - '24': {'OS': 'NEC MS-DOS 3.30', 'Description': 'Logical sectored FAT12 or FAT16 '}, - '25': {'OS': 'Windows Mobile', 'Description': 'Windows Mobile IMGFS[citation needed]'}, - '26': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '27': {'OS': 'Windows / PQservice / MirOS BSD / RooterBOOT', 'Description': 'Windows Recovery Environment (RE) partition (hidden NTFS partition type 07h) / FAT32 or NTFS rescue partition / MirOS partition / RooterBOOT kernel partition (contains a raw ELF Linux kernel, no file system)'}, - '2A': {'OS': 'AtheOS', 'Description': 'AtheOS file system (AthFS, AFS) (an extension of BFS, see 2Bh and EBh) / Reserved'}, - '2B': {'OS': 'SyllableOS', 'Description': 'SyllableSecure (SylStor), a variant of AthFS (an extension of BFS, see 2Ah and EBh)'}, - '31': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '32': {'OS': 'NOS', 'Description': 'Unknown'}, - '33': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '34': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '35': {'OS': 'OS/2 Warp Server /eComStation', 'Description': 'JFS (OS/2 implementation of AIX Journaling File system)'}, - '36': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '38': {'OS': 'THEOS', 'Description': 'THEOS version 3.2, 2 GB partition'}, - '39': {'OS': 'Plan 9 / THEOS', 'Description': 'Plan 9 edition 3 partition (sub-partitions described in second sector of partition) / THEOS version 4 spanned partition'}, - '3A': {'OS': 'THEOS', 'Description': 'THEOS version 4, 4 GB partition'}, - '3B': {'OS': 'THEOS', 'Description': 'THEOS version 4 extended partition'}, - '3C': {'OS': 'PartitionMagic', 'Description': 'PqRP (PartitionMagic or DriveImage in progress)'}, - '3D': {'OS': 'PartitionMagic', 'Description': 'Hidden NetWare'}, - '3F': {'OS': 'OS/32', 'Description': 'Unknown'}, - '40': {'OS': 'PICK / Venix', 'Description': 'PICK R83 / Venix 80286'}, - '41': {'OS': 'Personal RISC / Linux / PowerPC', 'Description': 'Personal RISC Boot / Old Linux/Minix (disk shared with DR DOS 6.0) / PPC PReP (Power PC Reference Platform) Boot'}, - '42': {'OS': 'SFS / Linux / Windows 2000, XP, etc.', 'Description': 'Secure File system (SFS) / Old Linux swap (disk shared with DR DOS 6.0) / Dynamic extended partition marker'}, - '43': {'OS': 'Linux', 'Description': 'Old Linux native (disk shared with DR DOS 6.0) '}, - '44': {'OS': 'GoBack', 'Description': 'Norton GoBack, WildFile GoBack, Adaptec GoBack, Roxio GoBack'}, - '45': {'OS': 'Boot-US / EUMEL/ELAN', 'Description': 'Priam / Boot-US boot manager (1 cylinder) / EUMEL/ELAN (L2)'}, - '46': {'OS': 'EUMEL/ELAN', 'Description': 'EUMEL/ELAN (L2)'}, - '47': {'OS': 'EUMEL/ELAN', 'Description': 'EUMEL/ELAN (L2)'}, - '48': {'OS': 'EUMEL/ELAN', 'Description': 'EUMEL/ELAN (L2), ERGOS L3'}, - '4A': {'OS': 'AdaOS / ALFS/THIN', 'Description': 'Aquila / ALFS/THIN advanced lightweight file system for DOS'}, - '4C': {'OS': 'ETH Oberon', 'Description': 'Aos (A2) file system (76)'}, - '4D': {'OS': 'QNX 4.x, Neutrino', 'Description': 'Primary QNX POSIX volume on disk (77)'}, - '4E': {'OS': 'QNX 4.x, Neutrino', 'Description': 'Secondary QNX POSIX volume on disk (78)'}, - '4F': {'OS': 'QNX 4.x, Neutrino / ETH Oberon', 'Description': 'Tertiary QNX POSIX volume on disk (79) / boot / native file system (79)'}, - '50': {'OS': 'ETH Oberon / Disk Manager 4 / LynxOS / Novell', 'Description': 'Alternative native file system (80) / Read-only partition (old) / Lynx RTOS'}, - '51': {'OS': 'Disk Manager 4-6', 'Description': 'Read-write partition (Aux 1)'}, - '52': {'OS': 'CP/M-80 / System V/AT, V/386', 'Description': 'CP/M-80'}, - '53': {'OS': 'Disk Manager 6', 'Description': 'Auxiliary 3 (WO)'}, - '54': {'OS': 'Disk Manager 6', 'Description': 'Dynamic Drive Overlay (DDO)'}, - '55': {'OS': 'EZ-Drive', 'Description': 'EZ-Drive, Maxtor, MaxBlast, or DriveGuide INT 13h redirector volume'}, - '56': {'OS': 'AT&T MS-DOS 3.x / EZ-Drive / VFeature', 'Description': 'Logical sectored FAT12 or FAT16 / Disk Manager partition converted to EZ-BIOS / VFeature partitionned volume'}, - '57': {'OS': 'DrivePro', 'Description': 'VNDI partition'}, - '5C': {'OS': 'EDISK', 'Description': 'Priam EDisk Partitioned Volume '}, - '61': {'OS': 'SpeedStor', 'Description': 'Unknown'}, - '63': {'OS': 'Unix', 'Description': 'SCO Unix, ISC, UnixWare, AT&T System V/386, ix, MtXinu BSD 4.3 on Mach, GNU HURD'}, - '64': {'OS': 'SpeedStor / NetWare', 'Description': 'NetWare File System 286/2 / PC-ARMOUR'}, - '65': {'OS': 'NetWare', 'Description': 'NetWare File System 386'}, - '66': {'OS': 'NetWare / NetWare', 'Description': 'NetWare File System 386 / Storage Management Services (SMS)'}, - '67': {'OS': 'NetWare', 'Description': 'Wolf Mountain'}, - '68': {'OS': 'NetWare', 'Description': 'Unknown'}, - '69': {'OS': 'NetWare 5 / NetWare', 'Description': 'Novell Storage Services (NSS)'}, - '6E': {'Description': 'Unknown'}, - '70': {'OS': 'DiskSecure', 'Description': 'DiskSecure multiboot'}, - '71': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '72': {'OS': 'APTI conformant systems / Unix V7/x86', 'Description': 'APTI alternative FAT12 (CHS, SFN) / V7/x86'}, - '73': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '74': {'OS': 'Microsoft, IBM', 'Description': 'Reserved / Scramdisk'}, - '75': {'OS': 'PC/IX', 'Description': 'Unknown'}, - '76': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, - '77': {'OS': 'Novell', 'Description': 'VNDI, M2FS, M2CS'}, - '78': {'OS': 'Geurt Vos', 'Description': 'XOSL bootloader file system'}, - '79': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT16 (CHS, SFN) '}, - '7A': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT16 (LBA, SFN) '}, - '7B': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT16B (CHS, SFN) '}, - '7C': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT32 (LBA, SFN) '}, - '7D': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT32 (CHS, SFN) '}, - '7E': {'OS': 'F.I.X. (claim) / PrimoCache', 'Description': 'Level 2 cache'}, - '7F': {'OS': 'Varies', 'Description': 'Alternative OS Development Partition Standard - reserved for individual or local use and temporary or experimental projects'}, - '80': {'OS': 'Minix 1.1-1.4a', 'Description': 'Minix file system (old)'}, - '81': {'OS': 'Minix 1.4b+ / Linux', 'Description': 'MINIX file system / Mitac Advanced Disk Manager'}, - '82': {'OS': 'Linux / Sun Microsystems', 'Description': 'Linux swap space / Solaris x86 (for Sun disklabels up to 2005) / Prime'}, - '83': {'OS': 'GNU/Linux', 'Description': 'Any native Linux file system '}, - '84': {'OS': 'OS/2 / Windows 7', 'Description': 'APM hibernation (suspend to disk, S2D) / Hidden C: (FAT16) / Rapid Start technology'}, - '85': {'OS': 'GNU/Linux', 'Description': 'Linux extended '}, - '86': {'OS': 'Windows NT 4 Server / Linux', 'Description': 'Fault-tolerant FAT16B mirrored volume set / Linux RAID superblock with auto-detect (old)'}, - '87': {'OS': 'Windows NT 4 Server', 'Description': 'Fault-tolerant HPFS/NTFS mirrored volume set '}, - '88': {'OS': 'GNU/Linux', 'Description': 'Linux plaintext partition table'}, - '8A': {'OS': 'AiR-BOOT', 'Description': 'Linux kernel image'}, - '8B': {'OS': 'Windows NT 4 Server', 'Description': 'Legacy fault-tolerant FAT32 mirrored volume set '}, - '8C': {'OS': 'Windows NT 4 Server', 'Description': 'Legacy fault-tolerant FAT32 mirrored volume set '}, - '8D': {'OS': 'Free FDISK', 'Description': 'Hidden FAT12 '}, - '8E': {'OS': 'Linux', 'Description': 'Linux LVM'}, - '90': {'OS': 'Free FDISK', 'Description': 'Hidden FAT16 '}, - '91': {'OS': 'Free FDISK', 'Description': 'Hidden extended partition with CHS addressing '}, - '92': {'OS': 'Free FDISK', 'Description': 'Hidden FAT16B '}, - '93': {'OS': 'Amoeba / Linux', 'Description': 'Amoeba native file system / Hidden Linux file system'}, - '94': {'OS': 'Amoeba', 'Description': 'Amoeba bad block table'}, - '95': {'OS': 'EXOPC', 'Description': 'EXOPC native'}, - '96': {'OS': 'CHRP', 'Description': 'ISO-9660 file system'}, - '97': {'OS': 'Free FDISK', 'Description': 'Hidden FAT32 '}, - '98': {'OS': 'Free FDISK / ROM-DOS', 'Description': 'Hidden FAT32 / service partition (bootable FAT) ROM-DOS SuperBoot / service partition (bootable FAT)'}, - '99': {'OS': 'early Unix', 'Description': 'Unknown'}, - '9A': {'OS': 'Free FDISK', 'Description': 'Hidden FAT16 '}, - '9B': {'OS': 'Free FDISK', 'Description': 'Hidden extended partition with LBA '}, - '9E': {'OS': 'VSTA / ForthOS', 'Description': 'ForthOS (eForth port)'}, - '9F': {'OS': 'BSD/OS 3.0+, BSDI', 'Description': 'Unknown'}, - 'A0': {'OS': 'Hewlett Packard / Phoenix, IBM, Toshiba, Sony', 'Description': 'Diagnostic partition for HP laptops / Hibernate partition'}, - 'A1': {'OS': 'Hewlett Packard / Phoenix, NEC', 'Description': 'HP Volume Expansion (SpeedStor) / Hibernate partition'}, - 'A2': {'OS': 'Cyclone V', 'Description': 'Hard Processor System (HPS) ARM preloader'}, - 'A3': {'OS': 'Hewlett Packard', 'Description': 'HP Volume Expansion (SpeedStor)'}, - 'A4': {'OS': 'Hewlett Packard', 'Description': 'HP Volume Expansion (SpeedStor)'}, - 'A5': {'OS': 'BSD', 'Description': 'BSD slice (BSD/386, 386BSD, NetBSD (old), FreeBSD)'}, - 'A6': {'OS': 'OpenBSD', 'Description': 'HP Volume Expansion (SpeedStor) / OpenBSD slice'}, - 'A7': {'OS': 'NeXT', 'Description': 'NeXTSTEP'}, - 'A8': {'OS': 'Darwin, Mac OS X', 'Description': 'Apple Darwin, Mac OS X UFS'}, - 'A9': {'OS': 'NetBSD', 'Description': 'NetBSD slice'}, - 'AA': {'OS': 'MS-DOS', 'Description': 'Olivetti MS-DOS FAT12 (1.44 MB) '}, - 'AB': {'OS': 'Darwin, Mac OS X / GO! OS', 'Description': 'Apple Darwin, Mac OS X boot / GO!'}, - 'AD': {'OS': 'RISC OS', 'Description': 'ADFS / FileCore format'}, - 'AE': {'OS': 'ShagOS', 'Description': 'ShagOS file system'}, - 'AF': {'OS': 'ShagOS', 'Description': 'Apple Mac OS X HFS and HFS+ / ShagOS swap'}, - 'B0': {'OS': 'Boot-Star', 'Description': 'Boot-Star dummy partition'}, - 'B1': {'OS': 'QNX 6.x', 'Description': 'HP Volume Expansion (SpeedStor) / QNX Neutrino power-safe file system'}, - 'B2': {'OS': 'QNX 6.x', 'Description': 'QNX Neutrino power-safe file system'}, - 'B3': {'OS': 'QNX 6.x', 'Description': 'HP Volume Expansion (SpeedStor) / QNX Neutrino power-safe file system'}, - 'B4': {'OS': 'Hewlett Packard', 'Description': 'HP Volume Expansion (SpeedStor)'}, - 'B6': {'OS': 'Windows NT 4 Server', 'Description': 'HP Volume Expansion (SpeedStor) / Corrupted fault-tolerant FAT16B mirrored master volume '}, - 'B7': {'OS': 'BSDI (before 3.0) / Windows NT 4 Server', 'Description': 'BSDI native file system / swap / Corrupted fault-tolerant HPFS/NTFS mirrored master volume '}, - 'B8': {'OS': 'BSDI (before 3.0)', 'Description': 'BSDI swap / native file system'}, - 'BB': {'OS': 'BootWizard, OS Selector / Acronis True Image / Windows NT 4 Server', 'Description': 'PTS BootWizard 4 / OS Selector 5 for hidden partitions other than 01h, 04h, 06h, 07h, 0Bh, 0Ch, 0Eh and unformatted partitions / OEM Secure Zone (corresponds to BCh) / Corrupted fault-tolerant FAT32 mirrored master volume '}, - 'BC': {'OS': 'Windows NT 4 Server / Acronis True Image / Backup Capsule', 'Description': 'Corrupted fault-tolerant FAT32 mirrored master volume / Acronis Secure Zone / Backup Capsule'}, - 'BD': {'OS': 'BonnyDOS/286', 'Description': 'Unknown'}, - 'BE': {'OS': 'Solaris 8', 'Description': 'Solaris 8 boot'}, - 'BF': {'OS': 'Solaris', 'Description': 'Solaris x86 (for Sun disklabels, since 2005)'}, - 'C0': {'OS': 'DR-DOS, Multiuser DOS,REAL/32', 'Description': 'Secured FAT partition (smaller than 32 MB)'}, - 'C1': {'OS': 'DR DOS 6.0+', 'Description': 'Secured FAT12 '}, - 'C2': {'OS': 'Power Boot', 'Description': 'Hidden Linux native file system'}, - 'C3': {'OS': 'Power Boot', 'Description': 'Hidden Linux swap'}, - 'C4': {'OS': 'DR DOS 6.0+', 'Description': 'Secured FAT16 '}, - 'C5': {'OS': 'DR DOS 6.0+', 'Description': 'Secured extended partition with CHS addressing '}, - 'C6': {'OS': 'DR DOS 6.0+ / Windows NT 4 Server', 'Description': 'Secured FAT16B / Corrupted fault-tolerant FAT16B mirrored slave volume '}, - 'C7': {'OS': 'Syrinx / Windows NT 4 Server', 'Description': 'Syrinx boot / Corrupted fault-tolerant HPFS/NTFS mirrored slave volume '}, - 'C8': {'Description': 'Reserved for DR-DOS since 1997'}, - 'C9': {'Description': 'Reserved for DR-DOS since 1997'}, - 'CA': {'Description': 'Reserved for DR-DOS since 1997'}, - 'CB': {'OS': 'DR-DOS 7.0x / Windows NT 4 Server', 'Description': 'Secured FAT32 / Corrupted fault-tolerant FAT32 mirrored slave volume '}, - 'CC': {'OS': 'DR-DOS 7.0x / Windows NT 4 Server', 'Description': 'Secured FAT32 / Corrupted fault-tolerant FAT32 mirrored slave volume '}, - 'CD': {'OS': 'CTOS', 'Description': 'Memory dump'}, - 'CE': {'OS': 'DR-DOS 7.0x', 'Description': 'Secured FAT16B '}, - 'CF': {'OS': 'DR-DOS 7.0x', 'Description': 'Secured extended partition with LBA '}, - 'D0': {'OS': 'Multiuser DOS, REAL/32', 'Description': 'Secured FAT partition (larger than 32 MB)'}, - 'D1': {'OS': 'Multiuser DOS', 'Description': 'Secured FAT12 '}, - 'D4': {'OS': 'Multiuser DOS', 'Description': 'Secured FAT16 '}, - 'D5': {'OS': 'Multiuser DOS', 'Description': 'Secured extended partition with CHS addressing '}, - 'D6': {'OS': 'Multiuser DOS', 'Description': 'Secured FAT16B '}, - 'D8': {'OS': 'Digital Research', 'Description': 'CP/M-86 [citation needed]'}, - 'DA': {'OS': 'Powercopy Backup', 'Description': 'Non-file system data / Shielded disk'}, - 'DB': {'OS': 'CP/M-86,Concurrent CP/M-86,Concurrent DOS / CTOS / D800 / DRMK', 'Description': 'CP/M-86, Concurrent CP/M-86, Concurrent DOS / boot image for x86 supervisor CPU (SCPU) module / FAT32 system restore partition (DSR)'}, - 'DD': {'OS': 'CTOS', 'Description': 'Hidden memory dump'}, - 'DE': {'OS': 'Dell', 'Description': 'FAT16 utility/diagnostic partition'}, - 'DF': {'OS': 'DG/UX / BootIt / Aviion', 'Description': 'DG/UX virtual disk manager / EMBRM'}, - 'E0': {'OS': 'STMicroelectronics', 'Description': 'ST AVFS'}, - 'E1': {'OS': 'SpeedStor', 'Description': 'Extended FAT12 (> 1023 cylinder)'}, - 'E2': {'Description': 'DOS read-only (XFDISK)'}, - 'E3': {'OS': 'SpeedStor', 'Description': 'DOS read-only'}, - 'E4': {'OS': 'SpeedStor', 'Description': 'Extended FAT16 (< 1024 cylinder)'}, - 'E5': {'OS': 'Tandy MS-DOS', 'Description': 'Logical sectored FAT12 or FAT16'}, - 'E6': {'OS': 'SpeedStor', 'Description': 'Unknown'}, - 'E8': {'OS': 'LUKS', 'Description': 'Linux Unified Key Setup'}, - 'EB': {'OS': 'BeOS, Haiku', 'Description': 'BFS'}, - 'EC': {'OS': 'SkyOS', 'Description': 'SkyFS'}, - 'ED': {'OS': 'Sprytix / EDD 4', 'Description': 'EDC loader / GPT hybrid MBR'}, - 'EE': {'OS': 'EFI', 'Description': 'GPT protective MBR'}, - 'EF': {'OS': 'EFI', 'Description': 'EFI system partition can be a FAT12, FAT16, FAT32 (or other) file system'}, - 'F0': {'OS': 'Linux / OS/32', 'Description': 'PA-RISC Linux boot loader. It must reside in first physical 2 GB. / floppy'}, - 'F1': {'OS': 'SpeedStor', 'Description': 'Unknown'}, - 'F2': {'OS': 'Sperry IT MS-DOS 3.x, Unisys MS-DOS 3.3, Digital ResearchDOS Plus 2.1', 'Description': 'Logical sectored FAT12 or FAT16 secondary partition'}, - 'F3': {'OS': 'SpeedStor', 'Description': 'Unknown'}, - 'F4': {'OS': 'SpeedStor / Prologue', 'Description': '"large" DOS partition / single volume partition for NGF or TwinFS'}, - 'F5': {'OS': 'Prologue', 'Description': 'MD0-MD9 multi volume partition for NGF or TwinFS'}, - 'F6': {'OS': 'SpeedStor', 'Description': 'Unknown'}, - 'F7': {'OS': 'O.S.G. / X1', 'Description': 'EFAT / Solid State file system'}, - 'F9': {'OS': 'Linux', 'Description': 'pCache ext2/ext3 persistent cache'}, - 'FA': {'OS': 'Bochs', 'Description': 'x86 emulator'}, - 'FB': {'OS': 'VMware', 'Description': 'VMware VMFS file system partition'}, - 'FC': {'OS': 'VMware', 'Description': 'VMware swap / VMKCORE kernel dump partition'}, - 'FD': {'OS': 'Linux / FreeDOS', 'Description': 'Linux RAID superblock with auto-detect / Reserved for FreeDOS'}, - 'FE': {'OS': 'SpeedStor / LANstep / Windows NT / Linux', 'Description': 'partition > 1024 cylinder / PS/2 IML partition / PS/2 recovery partition (FAT12 reference disk floppy image), / Disk Administration hidden partition / old Linux LVM'}, - 'FF': {'OS': 'XENIX', 'Description': 'XENIX bad block table'}, - '00000000-0000-0000-0000-000000000000': {'Description': 'Unused entry'}, - '024DEE41-33E7-11D3-9D69-0008C781F39F': {'Description': 'MBR partition scheme'}, - 'C12A7328-F81F-11D2-BA4B-00A0C93EC93B': {'Description': 'EFI System partition'}, - '21686148-6449-6E6F-744E-656564454649': {'Description': 'BIOS Boot partition'}, - 'D3BFE2DE-3DAF-11DF-BA40-E3A556D89593': {'Description': 'Intel Fast Flash (iFFS) partition (for Intel Rapid Start technology)'}, - 'F4019732-066E-4E12-8273-346C5641494F': {'Description': 'Sony boot partition'}, - 'BFBFAFE7-A34F-448A-9A5B-6213EB736C22': {'Description': 'Lenovo boot partition'}, - 'E3C9E316-0B5C-4DB8-817D-F92DF00215AE': {'OS': 'Windows', 'Description': 'Microsoft Reserved Partition (MSR)'}, - 'EBD0A0A2-B9E5-4433-87C0-68B6B72699C7': {'OS': 'Windows', 'Description': 'Basic data partition'}, - '5808C8AA-7E8F-42E0-85D2-E1E90434CFB3': {'OS': 'Windows', 'Description': 'Logical Disk Manager (LDM) metadata partition'}, - 'AF9B60A0-1431-4F62-BC68-3311714A69AD': {'OS': 'Windows', 'Description': 'Logical Disk Manager data partition'}, - 'DE94BBA4-06D1-4D40-A16A-BFD50179D6AC': {'OS': 'Windows', 'Description': 'Windows Recovery Environment'}, - '37AFFC90-EF7D-4E96-91C3-2D7AE055B174': {'OS': 'Windows', 'Description': 'IBM General Parallel File System (GPFS) partition'}, - 'E75CAF8F-F680-4CEE-AFA3-B001E56EFC2D': {'OS': 'Windows', 'Description': 'Storage Spaces partition'}, - '75894C1E-3AEB-11D3-B7C1-7B03A0000000': {'OS': 'HP-UX', 'Description': 'Data partition'}, - 'E2A1E728-32E3-11D6-A682-7B03A0000000': {'OS': 'HP-UX', 'Description': 'Service Partition'}, - '0FC63DAF-8483-4772-8E79-3D69D8477DE4': {'OS': 'Linux', 'Description': 'Linux filesystem data'}, - 'A19D880F-05FC-4D3B-A006-743F0F84911E': {'OS': 'Linux', 'Description': 'RAID partition'}, - '44479540-F297-41B2-9AF7-D131D5F0458A': {'OS': 'Linux', 'Description': 'Root partition (x86)'}, - '4F68BCE3-E8CD-4DB1-96E7-FBCAF984B709': {'OS': 'Linux', 'Description': 'Root partition (x86-64)'}, - '69DAD710-2CE4-4E3C-B16C-21A1D49ABED3': {'OS': 'Linux', 'Description': 'Root partition (32-bit ARM)'}, - 'B921B045-1DF0-41C3-AF44-4C6F280D3FAE': {'OS': 'Linux', 'Description': 'Root partition (64-bit ARM/AArch64)'}, - '0657FD6D-A4AB-43C4-84E5-0933C84B4F4F': {'OS': 'Linux', 'Description': 'Swap partition'}, - 'E6D6D379-F507-44C2-A23C-238F2A3DF928': {'OS': 'Linux', 'Description': 'Logical Volume Manager (LVM) partition'}, - '933AC7E1-2EB4-4F13-B844-0E14E2AEF915': {'OS': 'Linux', 'Description': '/home partition'}, - '3B8F8425-20E0-4F3B-907F-1A25A76F98E8': {'OS': 'Linux', 'Description': '/srv (server data) partition'}, - '7FFEC5C9-2D00-49B7-8941-3EA10A5586B7': {'OS': 'Linux', 'Description': 'Plain dm-crypt partition'}, - 'CA7D7CCB-63ED-4C53-861C-1742536059CC': {'OS': 'Linux', 'Description': 'LUKS partition'}, - '8DA63339-0007-60C0-C436-083AC8230908': {'OS': 'Linux', 'Description': 'Reserved'}, - '83BD6B9D-7F41-11DC-BE0B-001560B84F0F': {'OS': 'FreeBSD', 'Description': 'Boot partition'}, - '516E7CB4-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Data partition'}, - '516E7CB5-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Swap partition'}, - '516E7CB6-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Unix File System (UFS) partition'}, - '516E7CB8-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Vinum volume manager partition'}, - '516E7CBA-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'ZFS partition'}, - '48465300-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Hierarchical File System Plus (HFS+) partition'}, - '55465300-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple UFS'}, - '6A898CC3-1DD2-11B2-99A6-080020736631': {'OS': 'OS X Darwin', 'Description': 'ZFS'}, - '52414944-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple RAID partition'}, - '52414944-5F4F-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple RAID partition, offline'}, - '426F6F74-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple Boot partition (Recovery HD)'}, - '4C616265-6C00-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple Label'}, - '5265636F-7665-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple TV Recovery partition'}, - '53746F72-6167-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple Core Storage (i.e. Lion FileVault) partition'}, - '6A82CB45-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Boot partition'}, - '6A85CF4D-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Root partition'}, - '6A87C46F-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Swap partition'}, - '6A8B642B-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Backup partition'}, - '6A898CC3-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': '/usr partition'}, - '6A8EF2E9-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': '/var partition'}, - '6A90BA39-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': '/home partition'}, - '6A9283A5-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Alternate sector'}, - '6A945A3B-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Reserved partition'}, - '6A9630D1-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, - '6A980767-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, - '6A96237F-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, - '6A8D2AC7-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, - '49F48D32-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'Swap partition'}, - '49F48D5A-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'FFS partition'}, - '49F48D82-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'LFS partition'}, - '49F48DAA-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'RAID partition'}, - '2DB519C4-B10F-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'Concatenated partition'}, - '2DB519EC-B10F-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'Encrypted partition'}, - 'FE3A2A5D-4F32-41A7-B725-ACCC3285A309': {'OS': 'ChromeOS', 'Description': 'ChromeOS kernel'}, - '3CB8E202-3B7E-47DD-8A3C-7FF2A13CFCEC': {'OS': 'ChromeOS', 'Description': 'ChromeOS rootfs'}, - '2E0A753D-9E48-43B0-8337-B15192CB1B5E': {'OS': 'ChromeOS', 'Description': 'ChromeOS future use'}, - '42465331-3BA3-10F1-802A-4861696B7521': {'OS': 'Haiku', 'Description': 'Haiku BFS'}, - '85D5E45E-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Boot partition'}, - '85D5E45A-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Data partition'}, - '85D5E45B-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Swap partition'}, - '0394EF8B-237E-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Unix File System (UFS) partition'}, - '85D5E45C-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Vinum volume manager partition'}, - '85D5E45D-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'ZFS partition'}, - '45B0969E-9B03-4F30-B4C6-B4B80CEFF106': {'OS': 'Ceph', 'Description': 'Ceph Journal'}, - '45B0969E-9B03-4F30-B4C6-5EC00CEFF106': {'OS': 'Ceph', 'Description': 'Ceph dm-crypt Encrypted Journal'}, - '4FBD7E29-9D25-41B8-AFD0-062C0CEFF05D': {'OS': 'Ceph', 'Description': 'Ceph OSD'}, - '4FBD7E29-9D25-41B8-AFD0-5EC00CEFF05D': {'OS': 'Ceph', 'Description': 'Ceph dm-crypt OSD'}, - '89C57F98-2FE5-4DC0-89C1-F3AD0CEFF2BE': {'OS': 'Ceph', 'Description': 'Ceph disk in creation'}, - '89C57F98-2FE5-4DC0-89C1-5EC00CEFF2BE': {'OS': 'Ceph', 'Description': 'Ceph dm-crypt disk in creation'}, - '824CC7A0-36A8-11E3-890A-952519AD3F61': {'OS': 'OpenBSD', 'Description': 'Data partition'}, - 'CEF5A9AD-73BC-4601-89F3-CDEEEEE321A1': {'OS': 'QNX', 'Description': 'Power-safe (QNX6) file system'}, - 'C91818F9-8025-47AF-89D2-F030D7000C2C': {'OS': 'Plan 9', 'Description': 'Plan 9 partition'}, - '9D275380-40AD-11DB-BF97-000C2911D1B8': {'OS': 'VMware ESX', 'Description': 'vmkcore (coredump partition)'}, - 'AA31E02A-400F-11DB-9590-000C2911D1B8': {'OS': 'VMware ESX', 'Description': 'VMFS filesystem partition'}, - '9198EFFC-31C0-11DB-8F78-000C2911D1B8': {'OS': 'VMware ESX', 'Description': 'VMware Reserved'}, - '2568845D-2332-4675-BC39-8FA5A4748D15': {'OS': 'Android-IA', 'Description': 'Bootloader'}, - '114EAFFE-1552-4022-B26E-9B053604CF84': {'OS': 'Android-IA', 'Description': 'Bootloader2'}, - '49A4D17F-93A3-45C1-A0DE-F50B2EBE2599': {'OS': 'Android-IA', 'Description': 'Boot'}, - '4177C722-9E92-4AAB-8644-43502BFD5506': {'OS': 'Android-IA', 'Description': 'Recovery'}, - 'EF32A33B-A409-486C-9141-9FFB711F6266': {'OS': 'Android-IA', 'Description': 'Misc'}, - '20AC26BE-20B7-11E3-84C5-6CFDB94711E9': {'OS': 'Android-IA', 'Description': 'Metadata'}, - '38F428E6-D326-425D-9140-6E0EA133647C': {'OS': 'Android-IA', 'Description': 'System'}, - 'A893EF21-E428-470A-9E55-0668FD91A2D9': {'OS': 'Android-IA', 'Description': 'Cache'}, - 'DC76DDA9-5AC1-491C-AF42-A82591580C0D': {'OS': 'Android-IA', 'Description': 'Data'}, - 'EBC597D0-2053-4B15-8B64-E0AAC75F4DB1': {'OS': 'Android-IA', 'Description': 'Persistent'}, - '8F68CC74-C5E5-48DA-BE91-A0C8C15E9C80': {'OS': 'Android-IA', 'Description': 'Factory'}, - '767941D0-2085-11E3-AD3B-6CFDB94711E9': {'OS': 'Android-IA', 'Description': 'Fastboot / Tertiary'}, - 'AC6D7924-EB71-4DF8-B48D-E267B27148FF': {'OS': 'Android-IA', 'Description': 'OEM'}, - '7412F7D5-A156-4B13-81DC-867174929325': {'OS': 'ONIE', 'Description': 'Boot'}, - 'D4E6E2CD-4469-46F3-B5CB-1BFF57AFC149': {'OS': 'ONIE', 'Description': 'Config'}, - '9E1A2D38-C612-4316-AA26-8B49521E5A8B': {'OS': 'PowerPC', 'Description': 'PReP boot'}, - 'BC13C2FF-59E6-4262-A352-B275FD6F7172': {'OS': 'Freedesktop', 'Description': 'Extended Boot Partition ($BOOT)'}, -} - -def lookup_guid(guid): - return PARTITION_UIDS.get(guid.upper(), None) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - PARTITION UIDs +# sources: https://en.wikipedia.org/wiki/GUID_Partition_Table +# https://en.wikipedia.org/wiki/Partition_type + +PARTITION_UIDS = { + '00': {'OS': 'All', 'Description': 'Empty partition entry'}, + '01': {'OS': 'DOS 2.0+', 'Description': 'FAT12 as primary partition in first physical 32 MB of disk or as logical drive anywhere on disk (else use 06hinstead)'}, + '02': {'OS': 'XENIX', 'Description': 'XENIX root'}, + '03': {'OS': 'XENIX', 'Description': 'XENIX usr'}, + '04': {'OS': 'DOS 3.0+', 'Description': 'FAT16 with less than 65536 sectors (32 MB). As primary partition it must reside in first physical 32 MB of disk, or as logical drive anywhere on disk (else use 06h instead).'}, + '05': {'OS': 'DOS (3.2) 3.3+ / SpeedStor', 'Description': 'Extended partition with CHS addressing. It must reside in first physical 8 GB of disk, else use 0Fh instead / can occur in SpeedStor MBRs'}, + '06': {'OS': 'DOS 3.31+', 'Description': 'FAT16B with 65536 or more sectors. It must reside in first physical 8 GB of disk, unless used for logical drives in an 0Fh extended partition (else use 0Eh instead). Also used for FAT12 and FAT16 volumes in primary partitions if they are not residing in first physical 32 MB of disk.'}, + '07': {'OS': 'OS/2 1.2+ / OS/2 1.2+, Windows NT / Windows NT / Windows Embedded CE / QNX 2', 'Description': 'IFS / HPFS / NTFS / exFAT / QNX "qnx" (7) (pre-1988 only)'}, + '08': {'OS': 'Commodore MS-DOS 3.x / OS/2 1.0-1.3 / AIX / QNX 1.x/2.x', 'Description': 'Logical sectored FAT12 or FAT16 / OS/2 (FAT?) / AIX boot/split / SplitDrive / QNX "qny" (8) / partition spanning multiple drives'}, + '09': {'OS': 'AIX / QNX 1.x/2.x / Coherent / OS-9', 'Description': 'AIX data/boot / QNX "qnz" (9) / Coherent file system / OS-9 RBF'}, + '0A': {'OS': 'OS/2 / Coherent', 'Description': 'OS/2 Boot Manager / Coherent swap partition'}, + '0B': {'OS': 'DOS 7.1+', 'Description': 'FAT32 with CHS addressing'}, + '0C': {'OS': 'DOS 7.1+', 'Description': 'FAT32 with LBA'}, + '0D': {'OS': 'Silicon Safe', 'Description': 'Reserved'}, + '0E': {'OS': 'DOS 7.0+', 'Description': 'FAT16B with LBA'}, + '0F': {'OS': 'DOS 7.0+', 'Description': 'Extended partition with LBA'}, + '10': {'OS': 'OPUS', 'Description': 'Unknown'}, + '11': {'OS': 'Leading Edge MS-DOS 3.x / OS/2 Boot Manager', 'Description': 'Logical sectored FAT12 or FAT16 / Hidden FAT12 '}, + '12': {'OS': 'Compaq Contura', 'Description': 'configuration partition (bootable FAT) / configuration partition / hibernation partition / diagnostics and firmware partition (bootable FAT) / service partition (bootable FAT) / Rescue and Recovery partition'}, + '14': {'OS': 'AST MS-DOS 3.x / OS/2 Boot Manager / Maverick OS', 'Description': 'Logical sectored FAT12 or FAT16 / Hidden FAT16 / Omega file system'}, + '15': {'OS': 'OS/2 Boot Manager / Maverick OS', 'Description': 'Hidden extended partition with CHS addressing / swap'}, + '16': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT16B '}, + '17': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden IFS / Hidden HPFS / Hidden NTFS / Hidden exFAT '}, + '18': {'OS': 'AST Windows', 'Description': 'AST Zero Volt Suspend or SmartSleep partition'}, + '19': {'OS': 'Willowtech Photon coS', 'Description': 'Willowtech Photon coS'}, + '1B': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT32 '}, + '1C': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT32 with LBA '}, + '1E': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden FAT16 with LBA '}, + '1F': {'OS': 'OS/2 Boot Manager', 'Description': 'Hidden extended partition with LBA addressing '}, + '20': {'OS': 'Windows Mobile', 'Description': 'Windows Mobile update XIP / Willowsoft Overture File System (OFS1)'}, + '21': {'OS': 'Oxygen', 'Description': 'HP Volume Expansion (SpeedStor) / FSo2 (Oxygen File System)'}, + '22': {'OS': 'Oxygen', 'Description': 'Oxygen Extended Partition Table'}, + '23': {'OS': 'Windows Mobile', 'Description': 'Reserved / Windows Mobile boot XIP'}, + '24': {'OS': 'NEC MS-DOS 3.30', 'Description': 'Logical sectored FAT12 or FAT16 '}, + '25': {'OS': 'Windows Mobile', 'Description': 'Windows Mobile IMGFS[citation needed]'}, + '26': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '27': {'OS': 'Windows / PQservice / MirOS BSD / RooterBOOT', 'Description': 'Windows Recovery Environment (RE) partition (hidden NTFS partition type 07h) / FAT32 or NTFS rescue partition / MirOS partition / RooterBOOT kernel partition (contains a raw ELF Linux kernel, no file system)'}, + '2A': {'OS': 'AtheOS', 'Description': 'AtheOS file system (AthFS, AFS) (an extension of BFS, see 2Bh and EBh) / Reserved'}, + '2B': {'OS': 'SyllableOS', 'Description': 'SyllableSecure (SylStor), a variant of AthFS (an extension of BFS, see 2Ah and EBh)'}, + '31': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '32': {'OS': 'NOS', 'Description': 'Unknown'}, + '33': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '34': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '35': {'OS': 'OS/2 Warp Server /eComStation', 'Description': 'JFS (OS/2 implementation of AIX Journaling File system)'}, + '36': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '38': {'OS': 'THEOS', 'Description': 'THEOS version 3.2, 2 GB partition'}, + '39': {'OS': 'Plan 9 / THEOS', 'Description': 'Plan 9 edition 3 partition (sub-partitions described in second sector of partition) / THEOS version 4 spanned partition'}, + '3A': {'OS': 'THEOS', 'Description': 'THEOS version 4, 4 GB partition'}, + '3B': {'OS': 'THEOS', 'Description': 'THEOS version 4 extended partition'}, + '3C': {'OS': 'PartitionMagic', 'Description': 'PqRP (PartitionMagic or DriveImage in progress)'}, + '3D': {'OS': 'PartitionMagic', 'Description': 'Hidden NetWare'}, + '3F': {'OS': 'OS/32', 'Description': 'Unknown'}, + '40': {'OS': 'PICK / Venix', 'Description': 'PICK R83 / Venix 80286'}, + '41': {'OS': 'Personal RISC / Linux / PowerPC', 'Description': 'Personal RISC Boot / Old Linux/Minix (disk shared with DR DOS 6.0) / PPC PReP (Power PC Reference Platform) Boot'}, + '42': {'OS': 'SFS / Linux / Windows 2000, XP, etc.', 'Description': 'Secure File system (SFS) / Old Linux swap (disk shared with DR DOS 6.0) / Dynamic extended partition marker'}, + '43': {'OS': 'Linux', 'Description': 'Old Linux native (disk shared with DR DOS 6.0) '}, + '44': {'OS': 'GoBack', 'Description': 'Norton GoBack, WildFile GoBack, Adaptec GoBack, Roxio GoBack'}, + '45': {'OS': 'Boot-US / EUMEL/ELAN', 'Description': 'Priam / Boot-US boot manager (1 cylinder) / EUMEL/ELAN (L2)'}, + '46': {'OS': 'EUMEL/ELAN', 'Description': 'EUMEL/ELAN (L2)'}, + '47': {'OS': 'EUMEL/ELAN', 'Description': 'EUMEL/ELAN (L2)'}, + '48': {'OS': 'EUMEL/ELAN', 'Description': 'EUMEL/ELAN (L2), ERGOS L3'}, + '4A': {'OS': 'AdaOS / ALFS/THIN', 'Description': 'Aquila / ALFS/THIN advanced lightweight file system for DOS'}, + '4C': {'OS': 'ETH Oberon', 'Description': 'Aos (A2) file system (76)'}, + '4D': {'OS': 'QNX 4.x, Neutrino', 'Description': 'Primary QNX POSIX volume on disk (77)'}, + '4E': {'OS': 'QNX 4.x, Neutrino', 'Description': 'Secondary QNX POSIX volume on disk (78)'}, + '4F': {'OS': 'QNX 4.x, Neutrino / ETH Oberon', 'Description': 'Tertiary QNX POSIX volume on disk (79) / boot / native file system (79)'}, + '50': {'OS': 'ETH Oberon / Disk Manager 4 / LynxOS / Novell', 'Description': 'Alternative native file system (80) / Read-only partition (old) / Lynx RTOS'}, + '51': {'OS': 'Disk Manager 4-6', 'Description': 'Read-write partition (Aux 1)'}, + '52': {'OS': 'CP/M-80 / System V/AT, V/386', 'Description': 'CP/M-80'}, + '53': {'OS': 'Disk Manager 6', 'Description': 'Auxiliary 3 (WO)'}, + '54': {'OS': 'Disk Manager 6', 'Description': 'Dynamic Drive Overlay (DDO)'}, + '55': {'OS': 'EZ-Drive', 'Description': 'EZ-Drive, Maxtor, MaxBlast, or DriveGuide INT 13h redirector volume'}, + '56': {'OS': 'AT&T MS-DOS 3.x / EZ-Drive / VFeature', 'Description': 'Logical sectored FAT12 or FAT16 / Disk Manager partition converted to EZ-BIOS / VFeature partitionned volume'}, + '57': {'OS': 'DrivePro', 'Description': 'VNDI partition'}, + '5C': {'OS': 'EDISK', 'Description': 'Priam EDisk Partitioned Volume '}, + '61': {'OS': 'SpeedStor', 'Description': 'Unknown'}, + '63': {'OS': 'Unix', 'Description': 'SCO Unix, ISC, UnixWare, AT&T System V/386, ix, MtXinu BSD 4.3 on Mach, GNU HURD'}, + '64': {'OS': 'SpeedStor / NetWare', 'Description': 'NetWare File System 286/2 / PC-ARMOUR'}, + '65': {'OS': 'NetWare', 'Description': 'NetWare File System 386'}, + '66': {'OS': 'NetWare / NetWare', 'Description': 'NetWare File System 386 / Storage Management Services (SMS)'}, + '67': {'OS': 'NetWare', 'Description': 'Wolf Mountain'}, + '68': {'OS': 'NetWare', 'Description': 'Unknown'}, + '69': {'OS': 'NetWare 5 / NetWare', 'Description': 'Novell Storage Services (NSS)'}, + '6E': {'Description': 'Unknown'}, + '70': {'OS': 'DiskSecure', 'Description': 'DiskSecure multiboot'}, + '71': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '72': {'OS': 'APTI conformant systems / Unix V7/x86', 'Description': 'APTI alternative FAT12 (CHS, SFN) / V7/x86'}, + '73': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '74': {'OS': 'Microsoft, IBM', 'Description': 'Reserved / Scramdisk'}, + '75': {'OS': 'PC/IX', 'Description': 'Unknown'}, + '76': {'OS': 'Microsoft, IBM', 'Description': 'Reserved'}, + '77': {'OS': 'Novell', 'Description': 'VNDI, M2FS, M2CS'}, + '78': {'OS': 'Geurt Vos', 'Description': 'XOSL bootloader file system'}, + '79': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT16 (CHS, SFN) '}, + '7A': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT16 (LBA, SFN) '}, + '7B': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT16B (CHS, SFN) '}, + '7C': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT32 (LBA, SFN) '}, + '7D': {'OS': 'APTI conformant systems', 'Description': 'APTI alternative FAT32 (CHS, SFN) '}, + '7E': {'OS': 'F.I.X. (claim) / PrimoCache', 'Description': 'Level 2 cache'}, + '7F': {'OS': 'Varies', 'Description': 'Alternative OS Development Partition Standard - reserved for individual or local use and temporary or experimental projects'}, + '80': {'OS': 'Minix 1.1-1.4a', 'Description': 'Minix file system (old)'}, + '81': {'OS': 'Minix 1.4b+ / Linux', 'Description': 'MINIX file system / Mitac Advanced Disk Manager'}, + '82': {'OS': 'Linux / Sun Microsystems', 'Description': 'Linux swap space / Solaris x86 (for Sun disklabels up to 2005) / Prime'}, + '83': {'OS': 'GNU/Linux', 'Description': 'Any native Linux file system '}, + '84': {'OS': 'OS/2 / Windows 7', 'Description': 'APM hibernation (suspend to disk, S2D) / Hidden C: (FAT16) / Rapid Start technology'}, + '85': {'OS': 'GNU/Linux', 'Description': 'Linux extended '}, + '86': {'OS': 'Windows NT 4 Server / Linux', 'Description': 'Fault-tolerant FAT16B mirrored volume set / Linux RAID superblock with auto-detect (old)'}, + '87': {'OS': 'Windows NT 4 Server', 'Description': 'Fault-tolerant HPFS/NTFS mirrored volume set '}, + '88': {'OS': 'GNU/Linux', 'Description': 'Linux plaintext partition table'}, + '8A': {'OS': 'AiR-BOOT', 'Description': 'Linux kernel image'}, + '8B': {'OS': 'Windows NT 4 Server', 'Description': 'Legacy fault-tolerant FAT32 mirrored volume set '}, + '8C': {'OS': 'Windows NT 4 Server', 'Description': 'Legacy fault-tolerant FAT32 mirrored volume set '}, + '8D': {'OS': 'Free FDISK', 'Description': 'Hidden FAT12 '}, + '8E': {'OS': 'Linux', 'Description': 'Linux LVM'}, + '90': {'OS': 'Free FDISK', 'Description': 'Hidden FAT16 '}, + '91': {'OS': 'Free FDISK', 'Description': 'Hidden extended partition with CHS addressing '}, + '92': {'OS': 'Free FDISK', 'Description': 'Hidden FAT16B '}, + '93': {'OS': 'Amoeba / Linux', 'Description': 'Amoeba native file system / Hidden Linux file system'}, + '94': {'OS': 'Amoeba', 'Description': 'Amoeba bad block table'}, + '95': {'OS': 'EXOPC', 'Description': 'EXOPC native'}, + '96': {'OS': 'CHRP', 'Description': 'ISO-9660 file system'}, + '97': {'OS': 'Free FDISK', 'Description': 'Hidden FAT32 '}, + '98': {'OS': 'Free FDISK / ROM-DOS', 'Description': 'Hidden FAT32 / service partition (bootable FAT) ROM-DOS SuperBoot / service partition (bootable FAT)'}, + '99': {'OS': 'early Unix', 'Description': 'Unknown'}, + '9A': {'OS': 'Free FDISK', 'Description': 'Hidden FAT16 '}, + '9B': {'OS': 'Free FDISK', 'Description': 'Hidden extended partition with LBA '}, + '9E': {'OS': 'VSTA / ForthOS', 'Description': 'ForthOS (eForth port)'}, + '9F': {'OS': 'BSD/OS 3.0+, BSDI', 'Description': 'Unknown'}, + 'A0': {'OS': 'Hewlett Packard / Phoenix, IBM, Toshiba, Sony', 'Description': 'Diagnostic partition for HP laptops / Hibernate partition'}, + 'A1': {'OS': 'Hewlett Packard / Phoenix, NEC', 'Description': 'HP Volume Expansion (SpeedStor) / Hibernate partition'}, + 'A2': {'OS': 'Cyclone V', 'Description': 'Hard Processor System (HPS) ARM preloader'}, + 'A3': {'OS': 'Hewlett Packard', 'Description': 'HP Volume Expansion (SpeedStor)'}, + 'A4': {'OS': 'Hewlett Packard', 'Description': 'HP Volume Expansion (SpeedStor)'}, + 'A5': {'OS': 'BSD', 'Description': 'BSD slice (BSD/386, 386BSD, NetBSD (old), FreeBSD)'}, + 'A6': {'OS': 'OpenBSD', 'Description': 'HP Volume Expansion (SpeedStor) / OpenBSD slice'}, + 'A7': {'OS': 'NeXT', 'Description': 'NeXTSTEP'}, + 'A8': {'OS': 'Darwin, Mac OS X', 'Description': 'Apple Darwin, Mac OS X UFS'}, + 'A9': {'OS': 'NetBSD', 'Description': 'NetBSD slice'}, + 'AA': {'OS': 'MS-DOS', 'Description': 'Olivetti MS-DOS FAT12 (1.44 MB) '}, + 'AB': {'OS': 'Darwin, Mac OS X / GO! OS', 'Description': 'Apple Darwin, Mac OS X boot / GO!'}, + 'AD': {'OS': 'RISC OS', 'Description': 'ADFS / FileCore format'}, + 'AE': {'OS': 'ShagOS', 'Description': 'ShagOS file system'}, + 'AF': {'OS': 'ShagOS', 'Description': 'Apple Mac OS X HFS and HFS+ / ShagOS swap'}, + 'B0': {'OS': 'Boot-Star', 'Description': 'Boot-Star dummy partition'}, + 'B1': {'OS': 'QNX 6.x', 'Description': 'HP Volume Expansion (SpeedStor) / QNX Neutrino power-safe file system'}, + 'B2': {'OS': 'QNX 6.x', 'Description': 'QNX Neutrino power-safe file system'}, + 'B3': {'OS': 'QNX 6.x', 'Description': 'HP Volume Expansion (SpeedStor) / QNX Neutrino power-safe file system'}, + 'B4': {'OS': 'Hewlett Packard', 'Description': 'HP Volume Expansion (SpeedStor)'}, + 'B6': {'OS': 'Windows NT 4 Server', 'Description': 'HP Volume Expansion (SpeedStor) / Corrupted fault-tolerant FAT16B mirrored master volume '}, + 'B7': {'OS': 'BSDI (before 3.0) / Windows NT 4 Server', 'Description': 'BSDI native file system / swap / Corrupted fault-tolerant HPFS/NTFS mirrored master volume '}, + 'B8': {'OS': 'BSDI (before 3.0)', 'Description': 'BSDI swap / native file system'}, + 'BB': {'OS': 'BootWizard, OS Selector / Acronis True Image / Windows NT 4 Server', 'Description': 'PTS BootWizard 4 / OS Selector 5 for hidden partitions other than 01h, 04h, 06h, 07h, 0Bh, 0Ch, 0Eh and unformatted partitions / OEM Secure Zone (corresponds to BCh) / Corrupted fault-tolerant FAT32 mirrored master volume '}, + 'BC': {'OS': 'Windows NT 4 Server / Acronis True Image / Backup Capsule', 'Description': 'Corrupted fault-tolerant FAT32 mirrored master volume / Acronis Secure Zone / Backup Capsule'}, + 'BD': {'OS': 'BonnyDOS/286', 'Description': 'Unknown'}, + 'BE': {'OS': 'Solaris 8', 'Description': 'Solaris 8 boot'}, + 'BF': {'OS': 'Solaris', 'Description': 'Solaris x86 (for Sun disklabels, since 2005)'}, + 'C0': {'OS': 'DR-DOS, Multiuser DOS,REAL/32', 'Description': 'Secured FAT partition (smaller than 32 MB)'}, + 'C1': {'OS': 'DR DOS 6.0+', 'Description': 'Secured FAT12 '}, + 'C2': {'OS': 'Power Boot', 'Description': 'Hidden Linux native file system'}, + 'C3': {'OS': 'Power Boot', 'Description': 'Hidden Linux swap'}, + 'C4': {'OS': 'DR DOS 6.0+', 'Description': 'Secured FAT16 '}, + 'C5': {'OS': 'DR DOS 6.0+', 'Description': 'Secured extended partition with CHS addressing '}, + 'C6': {'OS': 'DR DOS 6.0+ / Windows NT 4 Server', 'Description': 'Secured FAT16B / Corrupted fault-tolerant FAT16B mirrored slave volume '}, + 'C7': {'OS': 'Syrinx / Windows NT 4 Server', 'Description': 'Syrinx boot / Corrupted fault-tolerant HPFS/NTFS mirrored slave volume '}, + 'C8': {'Description': 'Reserved for DR-DOS since 1997'}, + 'C9': {'Description': 'Reserved for DR-DOS since 1997'}, + 'CA': {'Description': 'Reserved for DR-DOS since 1997'}, + 'CB': {'OS': 'DR-DOS 7.0x / Windows NT 4 Server', 'Description': 'Secured FAT32 / Corrupted fault-tolerant FAT32 mirrored slave volume '}, + 'CC': {'OS': 'DR-DOS 7.0x / Windows NT 4 Server', 'Description': 'Secured FAT32 / Corrupted fault-tolerant FAT32 mirrored slave volume '}, + 'CD': {'OS': 'CTOS', 'Description': 'Memory dump'}, + 'CE': {'OS': 'DR-DOS 7.0x', 'Description': 'Secured FAT16B '}, + 'CF': {'OS': 'DR-DOS 7.0x', 'Description': 'Secured extended partition with LBA '}, + 'D0': {'OS': 'Multiuser DOS, REAL/32', 'Description': 'Secured FAT partition (larger than 32 MB)'}, + 'D1': {'OS': 'Multiuser DOS', 'Description': 'Secured FAT12 '}, + 'D4': {'OS': 'Multiuser DOS', 'Description': 'Secured FAT16 '}, + 'D5': {'OS': 'Multiuser DOS', 'Description': 'Secured extended partition with CHS addressing '}, + 'D6': {'OS': 'Multiuser DOS', 'Description': 'Secured FAT16B '}, + 'D8': {'OS': 'Digital Research', 'Description': 'CP/M-86 [citation needed]'}, + 'DA': {'OS': 'Powercopy Backup', 'Description': 'Non-file system data / Shielded disk'}, + 'DB': {'OS': 'CP/M-86,Concurrent CP/M-86,Concurrent DOS / CTOS / D800 / DRMK', 'Description': 'CP/M-86, Concurrent CP/M-86, Concurrent DOS / boot image for x86 supervisor CPU (SCPU) module / FAT32 system restore partition (DSR)'}, + 'DD': {'OS': 'CTOS', 'Description': 'Hidden memory dump'}, + 'DE': {'OS': 'Dell', 'Description': 'FAT16 utility/diagnostic partition'}, + 'DF': {'OS': 'DG/UX / BootIt / Aviion', 'Description': 'DG/UX virtual disk manager / EMBRM'}, + 'E0': {'OS': 'STMicroelectronics', 'Description': 'ST AVFS'}, + 'E1': {'OS': 'SpeedStor', 'Description': 'Extended FAT12 (> 1023 cylinder)'}, + 'E2': {'Description': 'DOS read-only (XFDISK)'}, + 'E3': {'OS': 'SpeedStor', 'Description': 'DOS read-only'}, + 'E4': {'OS': 'SpeedStor', 'Description': 'Extended FAT16 (< 1024 cylinder)'}, + 'E5': {'OS': 'Tandy MS-DOS', 'Description': 'Logical sectored FAT12 or FAT16'}, + 'E6': {'OS': 'SpeedStor', 'Description': 'Unknown'}, + 'E8': {'OS': 'LUKS', 'Description': 'Linux Unified Key Setup'}, + 'EB': {'OS': 'BeOS, Haiku', 'Description': 'BFS'}, + 'EC': {'OS': 'SkyOS', 'Description': 'SkyFS'}, + 'ED': {'OS': 'Sprytix / EDD 4', 'Description': 'EDC loader / GPT hybrid MBR'}, + 'EE': {'OS': 'EFI', 'Description': 'GPT protective MBR'}, + 'EF': {'OS': 'EFI', 'Description': 'EFI system partition can be a FAT12, FAT16, FAT32 (or other) file system'}, + 'F0': {'OS': 'Linux / OS/32', 'Description': 'PA-RISC Linux boot loader. It must reside in first physical 2 GB. / floppy'}, + 'F1': {'OS': 'SpeedStor', 'Description': 'Unknown'}, + 'F2': {'OS': 'Sperry IT MS-DOS 3.x, Unisys MS-DOS 3.3, Digital ResearchDOS Plus 2.1', 'Description': 'Logical sectored FAT12 or FAT16 secondary partition'}, + 'F3': {'OS': 'SpeedStor', 'Description': 'Unknown'}, + 'F4': {'OS': 'SpeedStor / Prologue', 'Description': '"large" DOS partition / single volume partition for NGF or TwinFS'}, + 'F5': {'OS': 'Prologue', 'Description': 'MD0-MD9 multi volume partition for NGF or TwinFS'}, + 'F6': {'OS': 'SpeedStor', 'Description': 'Unknown'}, + 'F7': {'OS': 'O.S.G. / X1', 'Description': 'EFAT / Solid State file system'}, + 'F9': {'OS': 'Linux', 'Description': 'pCache ext2/ext3 persistent cache'}, + 'FA': {'OS': 'Bochs', 'Description': 'x86 emulator'}, + 'FB': {'OS': 'VMware', 'Description': 'VMware VMFS file system partition'}, + 'FC': {'OS': 'VMware', 'Description': 'VMware swap / VMKCORE kernel dump partition'}, + 'FD': {'OS': 'Linux / FreeDOS', 'Description': 'Linux RAID superblock with auto-detect / Reserved for FreeDOS'}, + 'FE': {'OS': 'SpeedStor / LANstep / Windows NT / Linux', 'Description': 'partition > 1024 cylinder / PS/2 IML partition / PS/2 recovery partition (FAT12 reference disk floppy image), / Disk Administration hidden partition / old Linux LVM'}, + 'FF': {'OS': 'XENIX', 'Description': 'XENIX bad block table'}, + '00000000-0000-0000-0000-000000000000': {'Description': 'Unused entry'}, + '024DEE41-33E7-11D3-9D69-0008C781F39F': {'Description': 'MBR partition scheme'}, + 'C12A7328-F81F-11D2-BA4B-00A0C93EC93B': {'Description': 'EFI System partition'}, + '21686148-6449-6E6F-744E-656564454649': {'Description': 'BIOS Boot partition'}, + 'D3BFE2DE-3DAF-11DF-BA40-E3A556D89593': {'Description': 'Intel Fast Flash (iFFS) partition (for Intel Rapid Start technology)'}, + 'F4019732-066E-4E12-8273-346C5641494F': {'Description': 'Sony boot partition'}, + 'BFBFAFE7-A34F-448A-9A5B-6213EB736C22': {'Description': 'Lenovo boot partition'}, + 'E3C9E316-0B5C-4DB8-817D-F92DF00215AE': {'OS': 'Windows', 'Description': 'Microsoft Reserved Partition (MSR)'}, + 'EBD0A0A2-B9E5-4433-87C0-68B6B72699C7': {'OS': 'Windows', 'Description': 'Basic data partition'}, + '5808C8AA-7E8F-42E0-85D2-E1E90434CFB3': {'OS': 'Windows', 'Description': 'Logical Disk Manager (LDM) metadata partition'}, + 'AF9B60A0-1431-4F62-BC68-3311714A69AD': {'OS': 'Windows', 'Description': 'Logical Disk Manager data partition'}, + 'DE94BBA4-06D1-4D40-A16A-BFD50179D6AC': {'OS': 'Windows', 'Description': 'Windows Recovery Environment'}, + '37AFFC90-EF7D-4E96-91C3-2D7AE055B174': {'OS': 'Windows', 'Description': 'IBM General Parallel File System (GPFS) partition'}, + 'E75CAF8F-F680-4CEE-AFA3-B001E56EFC2D': {'OS': 'Windows', 'Description': 'Storage Spaces partition'}, + '75894C1E-3AEB-11D3-B7C1-7B03A0000000': {'OS': 'HP-UX', 'Description': 'Data partition'}, + 'E2A1E728-32E3-11D6-A682-7B03A0000000': {'OS': 'HP-UX', 'Description': 'Service Partition'}, + '0FC63DAF-8483-4772-8E79-3D69D8477DE4': {'OS': 'Linux', 'Description': 'Linux filesystem data'}, + 'A19D880F-05FC-4D3B-A006-743F0F84911E': {'OS': 'Linux', 'Description': 'RAID partition'}, + '44479540-F297-41B2-9AF7-D131D5F0458A': {'OS': 'Linux', 'Description': 'Root partition (x86)'}, + '4F68BCE3-E8CD-4DB1-96E7-FBCAF984B709': {'OS': 'Linux', 'Description': 'Root partition (x86-64)'}, + '69DAD710-2CE4-4E3C-B16C-21A1D49ABED3': {'OS': 'Linux', 'Description': 'Root partition (32-bit ARM)'}, + 'B921B045-1DF0-41C3-AF44-4C6F280D3FAE': {'OS': 'Linux', 'Description': 'Root partition (64-bit ARM/AArch64)'}, + '0657FD6D-A4AB-43C4-84E5-0933C84B4F4F': {'OS': 'Linux', 'Description': 'Swap partition'}, + 'E6D6D379-F507-44C2-A23C-238F2A3DF928': {'OS': 'Linux', 'Description': 'Logical Volume Manager (LVM) partition'}, + '933AC7E1-2EB4-4F13-B844-0E14E2AEF915': {'OS': 'Linux', 'Description': '/home partition'}, + '3B8F8425-20E0-4F3B-907F-1A25A76F98E8': {'OS': 'Linux', 'Description': '/srv (server data) partition'}, + '7FFEC5C9-2D00-49B7-8941-3EA10A5586B7': {'OS': 'Linux', 'Description': 'Plain dm-crypt partition'}, + 'CA7D7CCB-63ED-4C53-861C-1742536059CC': {'OS': 'Linux', 'Description': 'LUKS partition'}, + '8DA63339-0007-60C0-C436-083AC8230908': {'OS': 'Linux', 'Description': 'Reserved'}, + '83BD6B9D-7F41-11DC-BE0B-001560B84F0F': {'OS': 'FreeBSD', 'Description': 'Boot partition'}, + '516E7CB4-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Data partition'}, + '516E7CB5-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Swap partition'}, + '516E7CB6-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Unix File System (UFS) partition'}, + '516E7CB8-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'Vinum volume manager partition'}, + '516E7CBA-6ECF-11D6-8FF8-00022D09712B': {'OS': 'FreeBSD', 'Description': 'ZFS partition'}, + '48465300-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Hierarchical File System Plus (HFS+) partition'}, + '55465300-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple UFS'}, + '6A898CC3-1DD2-11B2-99A6-080020736631': {'OS': 'OS X Darwin', 'Description': 'ZFS'}, + '52414944-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple RAID partition'}, + '52414944-5F4F-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple RAID partition, offline'}, + '426F6F74-0000-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple Boot partition (Recovery HD)'}, + '4C616265-6C00-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple Label'}, + '5265636F-7665-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple TV Recovery partition'}, + '53746F72-6167-11AA-AA11-00306543ECAC': {'OS': 'OS X Darwin', 'Description': 'Apple Core Storage (i.e. Lion FileVault) partition'}, + '6A82CB45-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Boot partition'}, + '6A85CF4D-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Root partition'}, + '6A87C46F-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Swap partition'}, + '6A8B642B-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Backup partition'}, + '6A898CC3-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': '/usr partition'}, + '6A8EF2E9-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': '/var partition'}, + '6A90BA39-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': '/home partition'}, + '6A9283A5-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Alternate sector'}, + '6A945A3B-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos', 'Description': 'Reserved partition'}, + '6A9630D1-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, + '6A980767-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, + '6A96237F-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, + '6A8D2AC7-1DD2-11B2-99A6-080020736631': {'OS': 'Solaris illumos'}, + '49F48D32-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'Swap partition'}, + '49F48D5A-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'FFS partition'}, + '49F48D82-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'LFS partition'}, + '49F48DAA-B10E-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'RAID partition'}, + '2DB519C4-B10F-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'Concatenated partition'}, + '2DB519EC-B10F-11DC-B99B-0019D1879648': {'OS': 'NetBSD', 'Description': 'Encrypted partition'}, + 'FE3A2A5D-4F32-41A7-B725-ACCC3285A309': {'OS': 'ChromeOS', 'Description': 'ChromeOS kernel'}, + '3CB8E202-3B7E-47DD-8A3C-7FF2A13CFCEC': {'OS': 'ChromeOS', 'Description': 'ChromeOS rootfs'}, + '2E0A753D-9E48-43B0-8337-B15192CB1B5E': {'OS': 'ChromeOS', 'Description': 'ChromeOS future use'}, + '42465331-3BA3-10F1-802A-4861696B7521': {'OS': 'Haiku', 'Description': 'Haiku BFS'}, + '85D5E45E-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Boot partition'}, + '85D5E45A-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Data partition'}, + '85D5E45B-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Swap partition'}, + '0394EF8B-237E-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Unix File System (UFS) partition'}, + '85D5E45C-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'Vinum volume manager partition'}, + '85D5E45D-237C-11E1-B4B3-E89A8F7FC3A7': {'OS': 'MidnightBSD', 'Description': 'ZFS partition'}, + '45B0969E-9B03-4F30-B4C6-B4B80CEFF106': {'OS': 'Ceph', 'Description': 'Ceph Journal'}, + '45B0969E-9B03-4F30-B4C6-5EC00CEFF106': {'OS': 'Ceph', 'Description': 'Ceph dm-crypt Encrypted Journal'}, + '4FBD7E29-9D25-41B8-AFD0-062C0CEFF05D': {'OS': 'Ceph', 'Description': 'Ceph OSD'}, + '4FBD7E29-9D25-41B8-AFD0-5EC00CEFF05D': {'OS': 'Ceph', 'Description': 'Ceph dm-crypt OSD'}, + '89C57F98-2FE5-4DC0-89C1-F3AD0CEFF2BE': {'OS': 'Ceph', 'Description': 'Ceph disk in creation'}, + '89C57F98-2FE5-4DC0-89C1-5EC00CEFF2BE': {'OS': 'Ceph', 'Description': 'Ceph dm-crypt disk in creation'}, + '824CC7A0-36A8-11E3-890A-952519AD3F61': {'OS': 'OpenBSD', 'Description': 'Data partition'}, + 'CEF5A9AD-73BC-4601-89F3-CDEEEEE321A1': {'OS': 'QNX', 'Description': 'Power-safe (QNX6) file system'}, + 'C91818F9-8025-47AF-89D2-F030D7000C2C': {'OS': 'Plan 9', 'Description': 'Plan 9 partition'}, + '9D275380-40AD-11DB-BF97-000C2911D1B8': {'OS': 'VMware ESX', 'Description': 'vmkcore (coredump partition)'}, + 'AA31E02A-400F-11DB-9590-000C2911D1B8': {'OS': 'VMware ESX', 'Description': 'VMFS filesystem partition'}, + '9198EFFC-31C0-11DB-8F78-000C2911D1B8': {'OS': 'VMware ESX', 'Description': 'VMware Reserved'}, + '2568845D-2332-4675-BC39-8FA5A4748D15': {'OS': 'Android-IA', 'Description': 'Bootloader'}, + '114EAFFE-1552-4022-B26E-9B053604CF84': {'OS': 'Android-IA', 'Description': 'Bootloader2'}, + '49A4D17F-93A3-45C1-A0DE-F50B2EBE2599': {'OS': 'Android-IA', 'Description': 'Boot'}, + '4177C722-9E92-4AAB-8644-43502BFD5506': {'OS': 'Android-IA', 'Description': 'Recovery'}, + 'EF32A33B-A409-486C-9141-9FFB711F6266': {'OS': 'Android-IA', 'Description': 'Misc'}, + '20AC26BE-20B7-11E3-84C5-6CFDB94711E9': {'OS': 'Android-IA', 'Description': 'Metadata'}, + '38F428E6-D326-425D-9140-6E0EA133647C': {'OS': 'Android-IA', 'Description': 'System'}, + 'A893EF21-E428-470A-9E55-0668FD91A2D9': {'OS': 'Android-IA', 'Description': 'Cache'}, + 'DC76DDA9-5AC1-491C-AF42-A82591580C0D': {'OS': 'Android-IA', 'Description': 'Data'}, + 'EBC597D0-2053-4B15-8B64-E0AAC75F4DB1': {'OS': 'Android-IA', 'Description': 'Persistent'}, + '8F68CC74-C5E5-48DA-BE91-A0C8C15E9C80': {'OS': 'Android-IA', 'Description': 'Factory'}, + '767941D0-2085-11E3-AD3B-6CFDB94711E9': {'OS': 'Android-IA', 'Description': 'Fastboot / Tertiary'}, + 'AC6D7924-EB71-4DF8-B48D-E267B27148FF': {'OS': 'Android-IA', 'Description': 'OEM'}, + '7412F7D5-A156-4B13-81DC-867174929325': {'OS': 'ONIE', 'Description': 'Boot'}, + 'D4E6E2CD-4469-46F3-B5CB-1BFF57AFC149': {'OS': 'ONIE', 'Description': 'Config'}, + '9E1A2D38-C612-4316-AA26-8B49521E5A8B': {'OS': 'PowerPC', 'Description': 'PReP boot'}, + 'BC13C2FF-59E6-4262-A352-B275FD6F7172': {'OS': 'Freedesktop', 'Description': 'Extended Boot Partition ($BOOT)'}, +} + +def lookup_guid(guid): + return PARTITION_UIDS.get(guid.upper(), None) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/product_keys.py b/.bin/Scripts/functions/product_keys.py index 705f46e9..514d44fb 100644 --- a/.bin/Scripts/functions/product_keys.py +++ b/.bin/Scripts/functions/product_keys.py @@ -1,111 +1,111 @@ -# Wizard Kit: Functions - Product Keys - -from functions.common import * - -# Regex -REGEX_REGISTRY_DIRS = re.compile( - r'^(config$|RegBack$|System32$|Transfer|Win)', - re.IGNORECASE) -REGEX_SOFTWARE_HIVE = re.compile(r'^Software$', re.IGNORECASE) - -def extract_keys(): - """Extract keys from provided hives and return a dict.""" - keys = {} - - # Extract keys - extract_item('ProduKey', silent=True) - for hive in find_software_hives(): - cmd = [ - global_vars['Tools']['ProduKey'], - '/IEKeys', '0', - '/WindowsKeys', '1', - '/OfficeKeys', '1', - '/ExtractEdition', '1', - '/nosavereg', - '/regfile', hive, - '/scomma', ''] - try: - out = run_program(cmd) - except subprocess.CalledProcessError: - # Ignore and return empty dict - pass - else: - for line in out.stdout.decode().splitlines(): - # Add key to keys under product only if unique - tmp = line.split(',') - product = tmp[0] - key = tmp[2] - if product not in keys: - keys[product] = [] - if key not in keys[product]: - keys[product].append(key) - - # Done - return keys - -def list_clientdir_keys(): - """List product keys found in hives inside the ClientDir.""" - keys = extract_keys() - key_list = [] - if keys: - for product in sorted(keys): - key_list.append(product) - for key in sorted(keys[product]): - key_list.append(' {key}'.format(key=key)) - else: - key_list.append('No keys found.') - - return key_list - -def find_software_hives(): - """Search for transferred SW hives and return a list.""" - hives = [] - search_paths = [global_vars['ClientDir']] - - while len(search_paths) > 0: - for item in os.scandir(search_paths.pop(0)): - if item.is_dir() and REGEX_REGISTRY_DIRS.search(item.name): - search_paths.append(item.path) - if item.is_file() and REGEX_SOFTWARE_HIVE.search(item.name): - hives.append(item.path) - - return hives - -def get_product_keys(): - """List product keys from saved report.""" - keys = [] - log_file = r'{LogDir}\Product Keys (ProduKey).txt'.format(**global_vars) - with open (log_file, 'r') as f: - for line in f.readlines(): - if re.search(r'^Product Name', line): - line = re.sub(r'^Product Name\s+:\s+(.*)', r'\1', line.strip()) - keys.append(line) - - if keys: - return keys - else: - return ['No product keys found'] - -def run_produkey(): - """Run ProduKey and save report in the ClientDir.""" - extract_item('ProduKey', silent=True) - log_file = r'{LogDir}\Product Keys (ProduKey).txt'.format(**global_vars) - if not os.path.exists(log_file): - # Clear current configuration - for config in ['ProduKey.cfg', 'ProduKey64.cfg']: - config = r'{BinDir}\ProduKey\{config}'.format( - config=config, **global_vars) - try: - if os.path.exists(config): - os.remove(config) - except Exception: - pass - cmd = [ - global_vars['Tools']['ProduKey'], - '/nosavereg', - '/stext', - log_file] - run_program(cmd, check=False) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Product Keys + +from functions.common import * + +# Regex +REGEX_REGISTRY_DIRS = re.compile( + r'^(config$|RegBack$|System32$|Transfer|Win)', + re.IGNORECASE) +REGEX_SOFTWARE_HIVE = re.compile(r'^Software$', re.IGNORECASE) + +def extract_keys(): + """Extract keys from provided hives and return a dict.""" + keys = {} + + # Extract keys + extract_item('ProduKey', silent=True) + for hive in find_software_hives(): + cmd = [ + global_vars['Tools']['ProduKey'], + '/IEKeys', '0', + '/WindowsKeys', '1', + '/OfficeKeys', '1', + '/ExtractEdition', '1', + '/nosavereg', + '/regfile', hive, + '/scomma', ''] + try: + out = run_program(cmd) + except subprocess.CalledProcessError: + # Ignore and return empty dict + pass + else: + for line in out.stdout.decode().splitlines(): + # Add key to keys under product only if unique + tmp = line.split(',') + product = tmp[0] + key = tmp[2] + if product not in keys: + keys[product] = [] + if key not in keys[product]: + keys[product].append(key) + + # Done + return keys + +def list_clientdir_keys(): + """List product keys found in hives inside the ClientDir.""" + keys = extract_keys() + key_list = [] + if keys: + for product in sorted(keys): + key_list.append(product) + for key in sorted(keys[product]): + key_list.append(' {key}'.format(key=key)) + else: + key_list.append('No keys found.') + + return key_list + +def find_software_hives(): + """Search for transferred SW hives and return a list.""" + hives = [] + search_paths = [global_vars['ClientDir']] + + while len(search_paths) > 0: + for item in os.scandir(search_paths.pop(0)): + if item.is_dir() and REGEX_REGISTRY_DIRS.search(item.name): + search_paths.append(item.path) + if item.is_file() and REGEX_SOFTWARE_HIVE.search(item.name): + hives.append(item.path) + + return hives + +def get_product_keys(): + """List product keys from saved report.""" + keys = [] + log_file = r'{LogDir}\Product Keys (ProduKey).txt'.format(**global_vars) + with open (log_file, 'r') as f: + for line in f.readlines(): + if re.search(r'^Product Name', line): + line = re.sub(r'^Product Name\s+:\s+(.*)', r'\1', line.strip()) + keys.append(line) + + if keys: + return keys + else: + return ['No product keys found'] + +def run_produkey(): + """Run ProduKey and save report in the ClientDir.""" + extract_item('ProduKey', silent=True) + log_file = r'{LogDir}\Product Keys (ProduKey).txt'.format(**global_vars) + if not os.path.exists(log_file): + # Clear current configuration + for config in ['ProduKey.cfg', 'ProduKey64.cfg']: + config = r'{BinDir}\ProduKey\{config}'.format( + config=config, **global_vars) + try: + if os.path.exists(config): + os.remove(config) + except Exception: + pass + cmd = [ + global_vars['Tools']['ProduKey'], + '/nosavereg', + '/stext', + log_file] + run_program(cmd, check=False) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/repairs.py b/.bin/Scripts/functions/repairs.py index bf9c3cdd..5b9d5f16 100644 --- a/.bin/Scripts/functions/repairs.py +++ b/.bin/Scripts/functions/repairs.py @@ -1,126 +1,126 @@ -# Wizard Kit: Functions - Repairs - -from functions.common import * - -def run_chkdsk(repair=False): - """Run CHKDSK scan or schedule offline repairs.""" - if repair: - run_chkdsk_offline() - else: - run_chkdsk_scan() - -def run_chkdsk_scan(): - """Run CHKDSK in a "split window" and report errors.""" - if global_vars['OS']['Version'] in ['8', '10']: - cmd = ['chkdsk', global_vars['Env']['SYSTEMDRIVE'], '/scan', '/perf'] - else: - cmd = ['chkdsk', global_vars['Env']['SYSTEMDRIVE']] - out = run_program(cmd, check=False) - # retcode == 0: no issues - # retcode == 1: fixed issues (also happens when chkdsk.exe is killed?) - # retcode == 2: issues - if int(out.returncode) > 0: - # print_error(' ERROR: CHKDSK encountered errors') - raise GenericError - - # Save stderr - with open(r'{LogDir}\CHKDSK.err'.format(**global_vars), 'a') as f: - for line in out.stderr.decode().splitlines(): - f.write(line.strip() + '\n') - # Save stdout - with open(r'{LogDir}\CHKDSK.log'.format(**global_vars), 'a') as f: - for line in out.stdout.decode().splitlines(): - f.write(line.strip() + '\n') - -def run_chkdsk_offline(): - """Set filesystem 'dirty bit' to force a chkdsk during next boot.""" - cmd = [ - 'fsutil', 'dirty', - 'set', - global_vars['Env']['SYSTEMDRIVE']] - out = run_program(cmd, check=False) - if int(out.returncode) > 0: - raise GenericError - -def run_dism(repair=False): - """Run DISM /RestoreHealth, then /CheckHealth, and then report errors.""" - if global_vars['OS']['Version'] in ['8', '10']: - if repair: - # Restore Health - cmd = [ - 'DISM', '/Online', - '/Cleanup-Image', '/RestoreHealth', - r'/LogPath:"{LogDir}\DISM_RestoreHealth.log"'.format( - **global_vars), - '-new_console:n', '-new_console:s33V'] - else: - # Scan Health - cmd = [ - 'DISM', '/Online', - '/Cleanup-Image', '/ScanHealth', - r'/LogPath:"{LogDir}\DISM_ScanHealth.log"'.format( - **global_vars), - '-new_console:n', '-new_console:s33V'] - run_program(cmd, pipe=False, check=False, shell=True) - wait_for_process('dism') - # Now check health - cmd = [ - 'DISM', '/Online', - '/Cleanup-Image', '/CheckHealth', - r'/LogPath:"{LogDir}\DISM_CheckHealth.log"'.format(**global_vars)] - result = run_program(cmd, shell=True).stdout.decode() - # Check result - if 'no component store corruption detected' not in result.lower(): - raise GenericError - else: - raise UnsupportedOSError - -def run_kvrt(): - """Run KVRT.""" - extract_item('KVRT', silent=True) - os.makedirs(global_vars['QuarantineDir'], exist_ok=True) - cmd = [ - global_vars['Tools']['KVRT'], - '-accepteula', '-dontcryptsupportinfo', '-fixednames', - '-d', global_vars['QuarantineDir'], - '-processlevel', '3'] - popen_program(cmd, pipe=False) - -def run_sfc_scan(): - """Run SFC in a "split window" and report errors.""" - cmd = [ - r'{SYSTEMROOT}\System32\sfc.exe'.format(**global_vars['Env']), - '/scannow'] - out = run_program(cmd, check=False) - # Save stderr - with open(r'{LogDir}\SFC.err'.format(**global_vars), 'a') as f: - for line in out.stderr.decode('utf-8', 'ignore').splitlines(): - f.write(line.strip() + '\n') - # Save stdout - with open(r'{LogDir}\SFC.log'.format(**global_vars), 'a') as f: - for line in out.stdout.decode('utf-8', 'ignore').splitlines(): - f.write(line.strip() + '\n') - # Check result - log_text = out.stdout.decode('utf-8', 'ignore').replace('\0', '') - if re.findall(r'did\s+not\s+find\s+any\s+integrity\s+violations', log_text): - pass - elif re.findall(r'successfully\s+repaired\s+them', log_text): - raise GenericRepair - else: - raise GenericError - -def run_tdsskiller(): - """Run TDSSKiller.""" - extract_item('TDSSKiller', silent=True) - os.makedirs(r'{QuarantineDir}\TDSSKiller'.format( - **global_vars), exist_ok=True) - cmd = [ - global_vars['Tools']['TDSSKiller'], - '-l', r'{LogDir}\TDSSKiller.log'.format(**global_vars), - '-qpath', r'{QuarantineDir}\TDSSKiller'.format(**global_vars), - '-accepteula', '-accepteulaksn', - '-dcexact', '-tdlfs'] - run_program(cmd, pipe=False) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Repairs + +from functions.common import * + +def run_chkdsk(repair=False): + """Run CHKDSK scan or schedule offline repairs.""" + if repair: + run_chkdsk_offline() + else: + run_chkdsk_scan() + +def run_chkdsk_scan(): + """Run CHKDSK in a "split window" and report errors.""" + if global_vars['OS']['Version'] in ['8', '10']: + cmd = ['chkdsk', global_vars['Env']['SYSTEMDRIVE'], '/scan', '/perf'] + else: + cmd = ['chkdsk', global_vars['Env']['SYSTEMDRIVE']] + out = run_program(cmd, check=False) + # retcode == 0: no issues + # retcode == 1: fixed issues (also happens when chkdsk.exe is killed?) + # retcode == 2: issues + if int(out.returncode) > 0: + # print_error(' ERROR: CHKDSK encountered errors') + raise GenericError + + # Save stderr + with open(r'{LogDir}\CHKDSK.err'.format(**global_vars), 'a') as f: + for line in out.stderr.decode().splitlines(): + f.write(line.strip() + '\n') + # Save stdout + with open(r'{LogDir}\CHKDSK.log'.format(**global_vars), 'a') as f: + for line in out.stdout.decode().splitlines(): + f.write(line.strip() + '\n') + +def run_chkdsk_offline(): + """Set filesystem 'dirty bit' to force a chkdsk during next boot.""" + cmd = [ + 'fsutil', 'dirty', + 'set', + global_vars['Env']['SYSTEMDRIVE']] + out = run_program(cmd, check=False) + if int(out.returncode) > 0: + raise GenericError + +def run_dism(repair=False): + """Run DISM /RestoreHealth, then /CheckHealth, and then report errors.""" + if global_vars['OS']['Version'] in ['8', '10']: + if repair: + # Restore Health + cmd = [ + 'DISM', '/Online', + '/Cleanup-Image', '/RestoreHealth', + r'/LogPath:"{LogDir}\DISM_RestoreHealth.log"'.format( + **global_vars), + '-new_console:n', '-new_console:s33V'] + else: + # Scan Health + cmd = [ + 'DISM', '/Online', + '/Cleanup-Image', '/ScanHealth', + r'/LogPath:"{LogDir}\DISM_ScanHealth.log"'.format( + **global_vars), + '-new_console:n', '-new_console:s33V'] + run_program(cmd, pipe=False, check=False, shell=True) + wait_for_process('dism') + # Now check health + cmd = [ + 'DISM', '/Online', + '/Cleanup-Image', '/CheckHealth', + r'/LogPath:"{LogDir}\DISM_CheckHealth.log"'.format(**global_vars)] + result = run_program(cmd, shell=True).stdout.decode() + # Check result + if 'no component store corruption detected' not in result.lower(): + raise GenericError + else: + raise UnsupportedOSError + +def run_kvrt(): + """Run KVRT.""" + extract_item('KVRT', silent=True) + os.makedirs(global_vars['QuarantineDir'], exist_ok=True) + cmd = [ + global_vars['Tools']['KVRT'], + '-accepteula', '-dontcryptsupportinfo', '-fixednames', + '-d', global_vars['QuarantineDir'], + '-processlevel', '3'] + popen_program(cmd, pipe=False) + +def run_sfc_scan(): + """Run SFC in a "split window" and report errors.""" + cmd = [ + r'{SYSTEMROOT}\System32\sfc.exe'.format(**global_vars['Env']), + '/scannow'] + out = run_program(cmd, check=False) + # Save stderr + with open(r'{LogDir}\SFC.err'.format(**global_vars), 'a') as f: + for line in out.stderr.decode('utf-8', 'ignore').splitlines(): + f.write(line.strip() + '\n') + # Save stdout + with open(r'{LogDir}\SFC.log'.format(**global_vars), 'a') as f: + for line in out.stdout.decode('utf-8', 'ignore').splitlines(): + f.write(line.strip() + '\n') + # Check result + log_text = out.stdout.decode('utf-8', 'ignore').replace('\0', '') + if re.findall(r'did\s+not\s+find\s+any\s+integrity\s+violations', log_text): + pass + elif re.findall(r'successfully\s+repaired\s+them', log_text): + raise GenericRepair + else: + raise GenericError + +def run_tdsskiller(): + """Run TDSSKiller.""" + extract_item('TDSSKiller', silent=True) + os.makedirs(r'{QuarantineDir}\TDSSKiller'.format( + **global_vars), exist_ok=True) + cmd = [ + global_vars['Tools']['TDSSKiller'], + '-l', r'{LogDir}\TDSSKiller.log'.format(**global_vars), + '-qpath', r'{QuarantineDir}\TDSSKiller'.format(**global_vars), + '-accepteula', '-accepteulaksn', + '-dcexact', '-tdlfs'] + run_program(cmd, pipe=False) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/setup.py b/.bin/Scripts/functions/setup.py index 821c1e99..dfd59982 100644 --- a/.bin/Scripts/functions/setup.py +++ b/.bin/Scripts/functions/setup.py @@ -1,272 +1,272 @@ -# Wizard Kit: Functions - Setup - -from functions.common import * - -# STATIC VARIABLES -HKCU = winreg.HKEY_CURRENT_USER -HKLM = winreg.HKEY_LOCAL_MACHINE -SETTINGS_CLASSIC_START = { - r'Software\IvoSoft\ClassicShell\Settings': {}, - r'Software\IvoSoft\ClassicStartMenu': { - 'DWORD Items': {'ShowedStyle2': 1}, - }, - r'Software\IvoSoft\ClassicStartMenu\MRU': {}, - r'Software\IvoSoft\ClassicStartMenu\Settings': { - 'DWORD Items': {'SkipMetro': 1}, - 'SZ Items': { - 'MenuStyle': 'Win7', - 'RecentPrograms': 'Recent', - }, - }, - } -SETTINGS_EXPLORER_SYSTEM = { - # Disable Telemetry - r'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\DataCollection': { - 'DWORD Items': {'AllowTelemetry': 0}, - }, - r'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\DataCollection': { - 'DWORD Items': {'AllowTelemetry': 0}, - 'WOW64_32': True, - }, - r'SOFTWARE\Policies\Microsoft\Windows\DataCollection': { - 'DWORD Items': {'AllowTelemetry': 0}, - }, - # Disable Wi-Fi Sense - r'Software\Microsoft\PolicyManager\default\WiFi\AllowWiFiHotSpotReporting': { - 'DWORD Items': {'Value': 0}, - }, - r'Software\Microsoft\PolicyManager\default\WiFi\AllowAutoConnectToWiFiSenseHotspots': { - 'DWORD Items': {'Value': 0}, - }, - # Disable Location Tracking - r'SOFTWARE\Microsoft\Windows NT\CurrentVersion\Sensor\Overrides\{BFA794E4-F964-4FDB-90F6-51056BFE4B44}': { - 'DWORD Items': {'SensorPermissionState': 0}, - }, - r'System\CurrentControlSet\Services\lfsvc\Service\Configuration': { - 'Status': {'Value': 0}, - }, - } -SETTINGS_EXPLORER_USER = { - # Disable Cortana - r'Software\Microsoft\Personalization\Settings': { - 'DWORD Items': {'AcceptedPrivacyPolicy': 0}, - }, - r'Software\Microsoft\InputPersonalization': { - 'DWORD Items': { - 'RestrictImplicitTextCollection': 1, - 'RestrictImplicitInkCollection': 1 - }, - }, - r'Software\Microsoft\InputPersonalization\TrainedDataStore': { - 'DWORD Items': {'HarvestContacts': 1}, - }, - # Hide Search button / box - r'Software\Microsoft\Windows\CurrentVersion\Search': { - 'DWORD Items': {'SearchboxTaskbarMode': 0}, - }, - # Change default Explorer view to "Computer" - r'Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced': { - 'DWORD Items': {'LaunchTo': 1}, - }, - } -SETTINGS_GOOGLE_CHROME = { - r'Software\Google\Chrome\Extensions': { - 'WOW64_32': True, - }, - r'Software\Google\Chrome\Extensions\cjpalhdlnbpafiamejdnhcphjbkeiagm': { - 'SZ Items': { - 'update_url': 'https://clients2.google.com/service/update2/crx'}, - 'WOW64_32': True, - }, - r'Software\Google\Chrome\Extensions\pgdnlhfefecpicbbihgmbmffkjpaplco': { - 'SZ Items': { - 'update_url': 'https://clients2.google.com/service/update2/crx'}, - 'WOW64_32': True, - }, - } -VCR_REDISTS = [ - {'Name': 'Visual C++ 2008 SP1 x32...', - 'Cmd': [r'2008sp1\x32\vcredist.exe', '/qb! /norestart']}, - {'Name': 'Visual C++ 2008 SP1 x64...', - 'Cmd': [r'2008sp1\x64\vcredist.exe', '/qb! /norestart']}, - {'Name': 'Visual C++ 2010 x32...', - 'Cmd': [r'2010sp1\x32\vcredist.exe', '/passive', '/norestart']}, - {'Name': 'Visual C++ 2010 x64...', - 'Cmd': [r'2010sp1\x64\vcredist.exe', '/passive', '/norestart']}, - {'Name': 'Visual C++ 2012 Update 4 x32...', - 'Cmd': [r'2012u4\x32\vcredist.exe', '/passive', '/norestart']}, - {'Name': 'Visual C++ 2012 Update 4 x64...', - 'Cmd': [r'2012u4\x64\vcredist.exe', '/passive', '/norestart']}, - {'Name': 'Visual C++ 2013 x32...', - 'Cmd': [r'2013\x32\vcredist.exe', '/install', - '/passive', '/norestart']}, - {'Name': 'Visual C++ 2013 x64...', - 'Cmd': [r'2013\x64\vcredist.exe', '/install', - '/passive', '/norestart']}, - {'Name': 'Visual C++ 2017 x32...', - 'Cmd': [r'2017\x32\vcredist.exe', '/install', - '/passive', '/norestart']}, - {'Name': 'Visual C++ 2017 x64...', - 'Cmd': [r'2017\x64\vcredist.exe', '/install', - '/passive', '/norestart']}, - ] - -def config_classicstart(): - """Configure ClassicStart.""" - # User level, not system level - cs_exe = r'{PROGRAMFILES}\Classic Shell\ClassicStartMenu.exe'.format( - **global_vars['Env']) - skin = r'{PROGRAMFILES}\Classic Shell\Skins\Metro-Win10-Black.skin7'.format( - **global_vars['Env']) - extract_item('ClassicStartSkin', silent=True) - - # Stop Classic Start - run_program([cs_exe, '-exit'], check=False) - sleep(1) - kill_process('ClassicStartMenu.exe') - - # Configure - write_registry_settings(SETTINGS_CLASSIC_START, all_users=False) - if global_vars['OS']['Version'] == '10' and os.path.exists(skin): - # Enable Win10 theme if on Win10 - key_path = r'Software\IvoSoft\ClassicStartMenu\Settings' - with winreg.OpenKey(HKCU, key_path, access=winreg.KEY_WRITE) as key: - winreg.SetValueEx( - key, 'SkinW7', 0, winreg.REG_SZ, 'Metro-Win10-Black') - winreg.SetValueEx(key, 'SkinVariationW7', 0, winreg.REG_SZ, '') - - # Pin Browser to Start Menu (Classic) - firefox = r'{PROGRAMDATA}\Start Menu\Programs\Mozilla Firefox.lnk'.format( - **global_vars['Env']) - chrome = r'{PROGRAMDATA}\Start Menu\Programs\Google Chrome.lnk'.format( - **global_vars['Env']) - dest_path = r'{APPDATA}\ClassicShell\Pinned'.format(**global_vars['Env']) - source = None - dest = None - if os.path.exists(firefox): - source = firefox - dest = r'{}\Mozilla Firefox.lnk'.format(dest_path) - elif os.path.exists(chrome): - source = chrome - dest = r'{}\Google Chrome.lnk'.format(dest_path) - if source: - try: - os.makedirs(dest_path, exist_ok=True) - shutil.copy(source, dest) - except Exception: - pass # Meh, it's fine without - - # (Re)start Classic Start - run_program([cs_exe, '-exit'], check=False) - sleep(1) - kill_process('ClassicStartMenu.exe') - sleep(1) - popen_program(cs_exe) - -def write_registry_settings(settings, all_users=False): - """Write registry values from custom dict of dicts.""" - hive = HKCU - if all_users: - hive = HKLM - for k, v in settings.items(): - # CreateKey - access = winreg.KEY_WRITE - if 'WOW64_32' in v: - access = access | winreg.KEY_WOW64_32KEY - winreg.CreateKeyEx(hive, k, 0, access) - - # Create values - with winreg.OpenKeyEx(hive, k, 0, access) as key: - for name, value in v.get('DWORD Items', {}).items(): - winreg.SetValueEx(key, name, 0, winreg.REG_DWORD, value) - for name, value in v.get('SZ Items', {}).items(): - winreg.SetValueEx(key, name, 0, winreg.REG_SZ, value) - -def config_explorer_system(): - """Configure Windows Explorer for all users via Registry settings.""" - write_registry_settings(SETTINGS_EXPLORER_SYSTEM, all_users=True) - -def config_explorer_user(): - """Configure Windows Explorer for current user via Registry settings.""" - write_registry_settings(SETTINGS_EXPLORER_USER, all_users=False) - -def update_clock(): - """Set Timezone and sync clock.""" - run_program(['tzutil' ,'/s', TIME_ZONE], check=False) - run_program(['net', 'stop', 'w32ime'], check=False) - run_program( - ['w32tm', '/config', '/syncfromflags:manual', - '/manualpeerlist:"us.pool.ntp.org time.nist.gov time.windows.com"', - ], - check=False) - run_program(['net', 'start', 'w32ime'], check=False) - run_program(['w32tm', '/resync', '/nowait'], check=False) - -# Installations -def install_adobe_reader(): - """Install Adobe Reader.""" - cmd = [ - r'{BaseDir}\Installers\Extras\Office\Adobe Reader DC.exe'.format( - **global_vars), - '/sAll', - '/msi', '/norestart', '/quiet', - 'ALLUSERS=1', - 'EULA_ACCEPT=YES'] - try_and_print(message='Adobe Reader DC...', function=run_program, cmd=cmd) - -def install_chrome_extensions(): - """Update registry to 'install' Google Chrome extensions for all users.""" - write_registry_settings(SETTINGS_GOOGLE_CHROME, all_users=True) - -def install_classicstart_skin(): - """Extract ClassicStart skin to installation folder.""" - if global_vars['OS']['Version'] not in ['8', '10']: - raise UnsupportedOSError - extract_item('ClassicStartSkin', silent=True) - source = r'{BinDir}\ClassicStartSkin\Metro-Win10-Black.skin7'.format( - **global_vars) - dest_path = r'{PROGRAMFILES}\Classic Shell\Skins'.format( - **global_vars['Env']) - dest = r'{}\Metro-Win10-Black.skin7'.format(dest_path) - os.makedirs(dest_path, exist_ok=True) - shutil.copy(source, dest) - -def install_firefox_extensions(): - """Extract Firefox extensions to installation folder.""" - dist_path = r'{PROGRAMFILES}\Mozilla Firefox\distribution\extensions'.format( - **global_vars['Env']) - # Extract extension(s) to distribution folder - cmd = [ - global_vars['Tools']['SevenZip'], 'x', '-aos', '-bso0', '-bse0', - '-p{ArchivePassword}'.format(**global_vars), - '-o{dist_path}'.format(dist_path=dist_path), - r'{CBinDir}\FirefoxExtensions.7z'.format(**global_vars)] - run_program(cmd, check=False) - -def install_ninite_bundle(mse=False): - """Run Ninite file(s) based on OS version.""" - if global_vars['OS']['Version'] in ['8', '10']: - # Modern selection - popen_program(r'{BaseDir}\Installers\Extras\Bundles\Modern.exe'.format( - **global_vars)) - else: - # Legacy selection - if mse: - cmd = r'{BaseDir}\Installers\Extras\Security'.format(**global_vars) - cmd += r'\Microsoft Security Essentials.exe' - popen_program(cmd) - popen_program(r'{BaseDir}\Installers\Extras\Bundles\Legacy.exe'.format( - **global_vars)) - -def install_vcredists(): - """Install all supported Visual C++ runtimes.""" - extract_item('_vcredists', silent=True) - prev_dir = os.getcwd() - os.chdir(r'{BinDir}\_vcredists'.format(**global_vars)) - for vcr in VCR_REDISTS: - try_and_print(message=vcr['Name'], function=run_program, cmd=vcr['Cmd']) - - os.chdir(prev_dir) - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Setup + +from functions.common import * + +# STATIC VARIABLES +HKCU = winreg.HKEY_CURRENT_USER +HKLM = winreg.HKEY_LOCAL_MACHINE +SETTINGS_CLASSIC_START = { + r'Software\IvoSoft\ClassicShell\Settings': {}, + r'Software\IvoSoft\ClassicStartMenu': { + 'DWORD Items': {'ShowedStyle2': 1}, + }, + r'Software\IvoSoft\ClassicStartMenu\MRU': {}, + r'Software\IvoSoft\ClassicStartMenu\Settings': { + 'DWORD Items': {'SkipMetro': 1}, + 'SZ Items': { + 'MenuStyle': 'Win7', + 'RecentPrograms': 'Recent', + }, + }, + } +SETTINGS_EXPLORER_SYSTEM = { + # Disable Telemetry + r'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\DataCollection': { + 'DWORD Items': {'AllowTelemetry': 0}, + }, + r'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\DataCollection': { + 'DWORD Items': {'AllowTelemetry': 0}, + 'WOW64_32': True, + }, + r'SOFTWARE\Policies\Microsoft\Windows\DataCollection': { + 'DWORD Items': {'AllowTelemetry': 0}, + }, + # Disable Wi-Fi Sense + r'Software\Microsoft\PolicyManager\default\WiFi\AllowWiFiHotSpotReporting': { + 'DWORD Items': {'Value': 0}, + }, + r'Software\Microsoft\PolicyManager\default\WiFi\AllowAutoConnectToWiFiSenseHotspots': { + 'DWORD Items': {'Value': 0}, + }, + # Disable Location Tracking + r'SOFTWARE\Microsoft\Windows NT\CurrentVersion\Sensor\Overrides\{BFA794E4-F964-4FDB-90F6-51056BFE4B44}': { + 'DWORD Items': {'SensorPermissionState': 0}, + }, + r'System\CurrentControlSet\Services\lfsvc\Service\Configuration': { + 'Status': {'Value': 0}, + }, + } +SETTINGS_EXPLORER_USER = { + # Disable Cortana + r'Software\Microsoft\Personalization\Settings': { + 'DWORD Items': {'AcceptedPrivacyPolicy': 0}, + }, + r'Software\Microsoft\InputPersonalization': { + 'DWORD Items': { + 'RestrictImplicitTextCollection': 1, + 'RestrictImplicitInkCollection': 1 + }, + }, + r'Software\Microsoft\InputPersonalization\TrainedDataStore': { + 'DWORD Items': {'HarvestContacts': 1}, + }, + # Hide Search button / box + r'Software\Microsoft\Windows\CurrentVersion\Search': { + 'DWORD Items': {'SearchboxTaskbarMode': 0}, + }, + # Change default Explorer view to "Computer" + r'Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced': { + 'DWORD Items': {'LaunchTo': 1}, + }, + } +SETTINGS_GOOGLE_CHROME = { + r'Software\Google\Chrome\Extensions': { + 'WOW64_32': True, + }, + r'Software\Google\Chrome\Extensions\cjpalhdlnbpafiamejdnhcphjbkeiagm': { + 'SZ Items': { + 'update_url': 'https://clients2.google.com/service/update2/crx'}, + 'WOW64_32': True, + }, + r'Software\Google\Chrome\Extensions\pgdnlhfefecpicbbihgmbmffkjpaplco': { + 'SZ Items': { + 'update_url': 'https://clients2.google.com/service/update2/crx'}, + 'WOW64_32': True, + }, + } +VCR_REDISTS = [ + {'Name': 'Visual C++ 2008 SP1 x32...', + 'Cmd': [r'2008sp1\x32\vcredist.exe', '/qb! /norestart']}, + {'Name': 'Visual C++ 2008 SP1 x64...', + 'Cmd': [r'2008sp1\x64\vcredist.exe', '/qb! /norestart']}, + {'Name': 'Visual C++ 2010 x32...', + 'Cmd': [r'2010sp1\x32\vcredist.exe', '/passive', '/norestart']}, + {'Name': 'Visual C++ 2010 x64...', + 'Cmd': [r'2010sp1\x64\vcredist.exe', '/passive', '/norestart']}, + {'Name': 'Visual C++ 2012 Update 4 x32...', + 'Cmd': [r'2012u4\x32\vcredist.exe', '/passive', '/norestart']}, + {'Name': 'Visual C++ 2012 Update 4 x64...', + 'Cmd': [r'2012u4\x64\vcredist.exe', '/passive', '/norestart']}, + {'Name': 'Visual C++ 2013 x32...', + 'Cmd': [r'2013\x32\vcredist.exe', '/install', + '/passive', '/norestart']}, + {'Name': 'Visual C++ 2013 x64...', + 'Cmd': [r'2013\x64\vcredist.exe', '/install', + '/passive', '/norestart']}, + {'Name': 'Visual C++ 2017 x32...', + 'Cmd': [r'2017\x32\vcredist.exe', '/install', + '/passive', '/norestart']}, + {'Name': 'Visual C++ 2017 x64...', + 'Cmd': [r'2017\x64\vcredist.exe', '/install', + '/passive', '/norestart']}, + ] + +def config_classicstart(): + """Configure ClassicStart.""" + # User level, not system level + cs_exe = r'{PROGRAMFILES}\Classic Shell\ClassicStartMenu.exe'.format( + **global_vars['Env']) + skin = r'{PROGRAMFILES}\Classic Shell\Skins\Metro-Win10-Black.skin7'.format( + **global_vars['Env']) + extract_item('ClassicStartSkin', silent=True) + + # Stop Classic Start + run_program([cs_exe, '-exit'], check=False) + sleep(1) + kill_process('ClassicStartMenu.exe') + + # Configure + write_registry_settings(SETTINGS_CLASSIC_START, all_users=False) + if global_vars['OS']['Version'] == '10' and os.path.exists(skin): + # Enable Win10 theme if on Win10 + key_path = r'Software\IvoSoft\ClassicStartMenu\Settings' + with winreg.OpenKey(HKCU, key_path, access=winreg.KEY_WRITE) as key: + winreg.SetValueEx( + key, 'SkinW7', 0, winreg.REG_SZ, 'Metro-Win10-Black') + winreg.SetValueEx(key, 'SkinVariationW7', 0, winreg.REG_SZ, '') + + # Pin Browser to Start Menu (Classic) + firefox = r'{PROGRAMDATA}\Start Menu\Programs\Mozilla Firefox.lnk'.format( + **global_vars['Env']) + chrome = r'{PROGRAMDATA}\Start Menu\Programs\Google Chrome.lnk'.format( + **global_vars['Env']) + dest_path = r'{APPDATA}\ClassicShell\Pinned'.format(**global_vars['Env']) + source = None + dest = None + if os.path.exists(firefox): + source = firefox + dest = r'{}\Mozilla Firefox.lnk'.format(dest_path) + elif os.path.exists(chrome): + source = chrome + dest = r'{}\Google Chrome.lnk'.format(dest_path) + if source: + try: + os.makedirs(dest_path, exist_ok=True) + shutil.copy(source, dest) + except Exception: + pass # Meh, it's fine without + + # (Re)start Classic Start + run_program([cs_exe, '-exit'], check=False) + sleep(1) + kill_process('ClassicStartMenu.exe') + sleep(1) + popen_program(cs_exe) + +def write_registry_settings(settings, all_users=False): + """Write registry values from custom dict of dicts.""" + hive = HKCU + if all_users: + hive = HKLM + for k, v in settings.items(): + # CreateKey + access = winreg.KEY_WRITE + if 'WOW64_32' in v: + access = access | winreg.KEY_WOW64_32KEY + winreg.CreateKeyEx(hive, k, 0, access) + + # Create values + with winreg.OpenKeyEx(hive, k, 0, access) as key: + for name, value in v.get('DWORD Items', {}).items(): + winreg.SetValueEx(key, name, 0, winreg.REG_DWORD, value) + for name, value in v.get('SZ Items', {}).items(): + winreg.SetValueEx(key, name, 0, winreg.REG_SZ, value) + +def config_explorer_system(): + """Configure Windows Explorer for all users via Registry settings.""" + write_registry_settings(SETTINGS_EXPLORER_SYSTEM, all_users=True) + +def config_explorer_user(): + """Configure Windows Explorer for current user via Registry settings.""" + write_registry_settings(SETTINGS_EXPLORER_USER, all_users=False) + +def update_clock(): + """Set Timezone and sync clock.""" + run_program(['tzutil' ,'/s', TIME_ZONE], check=False) + run_program(['net', 'stop', 'w32ime'], check=False) + run_program( + ['w32tm', '/config', '/syncfromflags:manual', + '/manualpeerlist:"us.pool.ntp.org time.nist.gov time.windows.com"', + ], + check=False) + run_program(['net', 'start', 'w32ime'], check=False) + run_program(['w32tm', '/resync', '/nowait'], check=False) + +# Installations +def install_adobe_reader(): + """Install Adobe Reader.""" + cmd = [ + r'{BaseDir}\Installers\Extras\Office\Adobe Reader DC.exe'.format( + **global_vars), + '/sAll', + '/msi', '/norestart', '/quiet', + 'ALLUSERS=1', + 'EULA_ACCEPT=YES'] + try_and_print(message='Adobe Reader DC...', function=run_program, cmd=cmd) + +def install_chrome_extensions(): + """Update registry to 'install' Google Chrome extensions for all users.""" + write_registry_settings(SETTINGS_GOOGLE_CHROME, all_users=True) + +def install_classicstart_skin(): + """Extract ClassicStart skin to installation folder.""" + if global_vars['OS']['Version'] not in ['8', '10']: + raise UnsupportedOSError + extract_item('ClassicStartSkin', silent=True) + source = r'{BinDir}\ClassicStartSkin\Metro-Win10-Black.skin7'.format( + **global_vars) + dest_path = r'{PROGRAMFILES}\Classic Shell\Skins'.format( + **global_vars['Env']) + dest = r'{}\Metro-Win10-Black.skin7'.format(dest_path) + os.makedirs(dest_path, exist_ok=True) + shutil.copy(source, dest) + +def install_firefox_extensions(): + """Extract Firefox extensions to installation folder.""" + dist_path = r'{PROGRAMFILES}\Mozilla Firefox\distribution\extensions'.format( + **global_vars['Env']) + # Extract extension(s) to distribution folder + cmd = [ + global_vars['Tools']['SevenZip'], 'x', '-aos', '-bso0', '-bse0', + '-p{ArchivePassword}'.format(**global_vars), + '-o{dist_path}'.format(dist_path=dist_path), + r'{CBinDir}\FirefoxExtensions.7z'.format(**global_vars)] + run_program(cmd, check=False) + +def install_ninite_bundle(mse=False): + """Run Ninite file(s) based on OS version.""" + if global_vars['OS']['Version'] in ['8', '10']: + # Modern selection + popen_program(r'{BaseDir}\Installers\Extras\Bundles\Modern.exe'.format( + **global_vars)) + else: + # Legacy selection + if mse: + cmd = r'{BaseDir}\Installers\Extras\Security'.format(**global_vars) + cmd += r'\Microsoft Security Essentials.exe' + popen_program(cmd) + popen_program(r'{BaseDir}\Installers\Extras\Bundles\Legacy.exe'.format( + **global_vars)) + +def install_vcredists(): + """Install all supported Visual C++ runtimes.""" + extract_item('_vcredists', silent=True) + prev_dir = os.getcwd() + os.chdir(r'{BinDir}\_vcredists'.format(**global_vars)) + for vcr in VCR_REDISTS: + try_and_print(message=vcr['Name'], function=run_program, cmd=vcr['Cmd']) + + os.chdir(prev_dir) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/functions/update.py b/.bin/Scripts/functions/update.py index d610d8f3..0c75a4c5 100644 --- a/.bin/Scripts/functions/update.py +++ b/.bin/Scripts/functions/update.py @@ -1,893 +1,893 @@ -# Wizard Kit: Functions - Build / Update - -import requests - -from functions.common import * -from functions.data import * -from settings.launchers import * -from settings.music import * -from settings.sources import * - -def compress_and_remove_item(item): - try: - compress_item(item) - except: - raise GenericError - else: - remove_item(item.path) - -def compress_item(item): - # Prep - prev_dir = os.getcwd() - dest = '{}.7z'.format(item.path) - wd = item.path - include_str = '*' - if os.path.isfile(wd): - wd = os.path.abspath(r'{}\{}'.format(wd, os.path.pardir)) - include_str = item.name - os.chdir(wd) - - # Compress - cmd = [ - global_vars['Tools']['SevenZip'], - 'a', dest, - '-t7z', '-mx=7', '-myx=7', '-ms=on', '-mhe', '-bso0', '-bse0', - '-p{}'.format(ARCHIVE_PASSWORD), - include_str, - ] - run_program(cmd) - - # Done - os.chdir(prev_dir) - -def download_generic(out_dir, out_name, source_url): - """Downloads a file using requests.""" - ## Code based on this Q&A: https://stackoverflow.com/q/16694907 - ### Asked by: https://stackoverflow.com/users/427457/roman-podlinov - ### Edited by: https://stackoverflow.com/users/657427/christophe-roussy - ### Using answer: https://stackoverflow.com/a/39217788 - ### Answer from: https://stackoverflow.com/users/4323/john-zwinck - os.makedirs(out_dir, exist_ok=True) - out_path = '{}/{}'.format(out_dir, out_name) - try: - r = requests.get(source_url, stream=True) - with open(out_path, 'wb') as f: - shutil.copyfileobj(r.raw, f) - r.close() - except: - raise GenericError('Failed to download file.') - -def download_to_temp(out_name, source_url): - download_generic(global_vars['TmpDir'], out_name, source_url) - -def extract_generic(source, dest, mode='x', sz_args=[]): - cmd = [ - global_vars['Tools']['SevenZip'], - mode, source, r'-o{}'.format(dest), - '-aoa', '-bso0', '-bse0', - ] - cmd.extend(sz_args) - run_program(cmd) - -def extract_temp_to_bin(source, item, mode='x', sz_args=[]): - source = r'{}\{}'.format(global_vars['TmpDir'], source) - dest = r'{}\{}'.format(global_vars['BinDir'], item) - extract_generic(source, dest, mode, sz_args) - -def extract_temp_to_cbin(source, item, mode='x', sz_args=[]): - source = r'{}\{}'.format(global_vars['TmpDir'], source) - dest = r'{}\{}'.format(global_vars['CBinDir'], item) - include_path = r'{}\_include\{}'.format(global_vars['CBinDir'], item) - if os.path.exists(include_path): - shutil.copytree(include_path, dest) - extract_generic(source, dest, mode, sz_args) - -def generate_launcher(section, name, options): - # Prep - dest = r'{}\{}'.format(global_vars['BaseDir'], section) - if section == '(Root)': - dest = global_vars['BaseDir'] - full_path = r'{}\{}.cmd'.format(dest, name) - template = r'{}\Scripts\Launcher_Template.cmd'.format(global_vars['BinDir']) - - # Format options - f_options = {} - for opt in options.keys(): - # Values need to be a list to support the multi-line extra code sections - if opt == 'Extra Code': - f_options['rem EXTRA_CODE'] = options['Extra Code'] - elif re.search(r'^L_\w+', opt, re.IGNORECASE): - new_opt = 'set {}='.format(opt) - f_options[new_opt] = ['set {}={}'.format(opt, options[opt])] - - # Read template and update using f_options - out_text = [] - with open(template, 'r') as f: - for line in f.readlines(): - # Strip all lines to let Python handle/correct the CRLF endings - line = line.strip() - if line in f_options: - # Extend instead of append to support extra code sections - out_text.extend(f_options[line]) - else: - out_text.append(line) - - # Write file - os.makedirs(dest, exist_ok=True) - with open(full_path, 'w') as f: - # f.writelines(out_text) - f.write('\n'.join(out_text)) - -def remove_item(item_path): - if os.path.exists(item_path): - if os.path.isdir(item_path): - shutil.rmtree(item_path, ignore_errors=True) - else: - os.remove(item_path) - -def remove_from_kit(item): - item_locations = [] - for p in [global_vars['BinDir'], global_vars['CBinDir']]: - item_locations.append(r'{}\{}'.format(p, item)) - item_locations.append(r'{}\_Drivers\{}'.format(p, item)) - for item_path in item_locations: - remove_item(item_path) - -def remove_from_temp(item): - item_path = r'{}\{}'.format(global_vars['TmpDir'], item) - remove_item(item_path) - -def resolve_dynamic_url(source_url, regex): - """Scan source_url for a url using the regex provided; returns str.""" - # Load the download page - try: - download_page = requests.get(source_url) - except Exception: - # "Fail silently as the download_to_temp() function will catch it - return None - - # Scan for the url using the regex provided - url = None - for line in download_page.content.decode().splitlines(): - if re.search(regex, line): - url = line.strip() - url = re.sub(r'.*(a |)href="([^"]+)".*', r'\2', url) - url = re.sub(r".*(a |)href='([^']+)'.*", r'\2', url) - break - - # Return - return url - -def scan_for_net_installers(server, family_name, min_year): - if not server['Mounted']: - mount_network_share(server) - - if server['Mounted']: - for year in os.scandir(r'\\{IP}\{Share}'.format(**server)): - if int(year.name) < min_year: - # Don't support outdated installers - continue - for version in os.scandir(year.path): - section = r'Installers\Extras\{}\{}'.format( - family_name, year.name) - if section not in LAUNCHERS: - LAUNCHERS[section] = {} - name = version.name - if re.search(r'(exe|msi)$', name, re.IGNORECASE): - name = name[:-4] - if name not in LAUNCHERS[section]: - LAUNCHERS[section][name] = { - 'L_TYPE': family_name, - 'L_PATH': year.name, - 'L_ITEM': version.name, - } - umount_network_share(server) - -## Data Recovery ## -def update_testdisk(): - # Stop running processes - for exe in ['fidentify_win.exe', 'photorec_win.exe', - 'qphotorec_win.exe', 'testdisk_win.exe']: - kill_process(exe) - - # Remove existing folders - remove_from_kit('TestDisk') - - # Download - download_to_temp('testdisk_wip.zip', SOURCE_URLS['TestDisk']) - - # Extract files - extract_temp_to_cbin('testdisk_wip.zip', 'TestDisk') - dest = r'{}\TestDisk'.format(global_vars['CBinDir']) - for item in os.scandir(r'{}\testdisk-7.1-WIP'.format(dest)): - dest_item = '{}\{}'.format(dest, item.name) - if not os.path.exists(dest_item): - shutil.move(item.path, dest_item) - shutil.rmtree( - r'{}\TestDisk\testdisk-7.1-WIP'.format(global_vars['CBinDir'])) - - # Cleanup - remove_from_temp('testdisk_wip.zip') - -## Data Transfers ## -def update_fastcopy(): - ## NOTE: Lives in .bin uncompressed - # Stop running processes - for process in ['FastCopy.exe', 'FastCopy64.exe']: - kill_process(process) - - # Remove existing folders - remove_from_kit('FastCopy') - - # Download - download_to_temp('FastCopy32.zip', SOURCE_URLS['FastCopy32']) - download_to_temp('FastCopy64.zip', SOURCE_URLS['FastCopy64']) - - # Extract - extract_temp_to_bin('FastCopy64.zip', 'FastCopy', sz_args=['FastCopy.exe']) - shutil.move( - r'{}\FastCopy\FastCopy.exe'.format(global_vars['BinDir']), - r'{}\FastCopy\FastCopy64.exe'.format(global_vars['BinDir'])) - extract_temp_to_bin('FastCopy32.zip', 'FastCopy', sz_args=[r'-x!setup.exe', r'-x!*.dll']) - - # Cleanup - remove_from_temp('FastCopy32.zip') - remove_from_temp('FastCopy64.zip') - -def update_wimlib(): - # Stop running processes - kill_process('wimlib-imagex.exe') - - # Remove existing folders - remove_from_kit('wimlib') - - # Download - download_to_temp('wimlib32.zip', SOURCE_URLS['wimlib32']) - download_to_temp('wimlib64.zip', SOURCE_URLS['wimlib64']) - - # Extract - extract_generic( - r'{}\wimlib32.zip'.format(global_vars['TmpDir']), - r'{}\wimlib\x32'.format(global_vars['CBinDir'])) - extract_generic( - r'{}\wimlib64.zip'.format(global_vars['TmpDir']), - r'{}\wimlib\x64'.format(global_vars['CBinDir'])) - - # Cleanup - remove_from_temp('wimlib32.zip') - remove_from_temp('wimlib64.zip') - -def update_xyplorer(): - # Stop running processes - kill_process('XYplorerFree.exe') - - # Remove existing folders - remove_from_kit('XYplorerFree') - - # Download - download_to_temp('xyplorer_free.zip', SOURCE_URLS['XYplorerFree']) - - # Extract files - extract_temp_to_cbin('xyplorer_free.zip', 'XYplorerFree') - - # Cleanup - remove_from_temp('xyplorer_free.zip') - -## Diagnostics ## -def update_aida64(): - # Stop running processes - kill_process('notepadplusplus.exe') - - # Remove existing folders - remove_from_kit('AIDA64') - - # Download - download_to_temp('aida64.zip', SOURCE_URLS['AIDA64']) - - # Extract files - extract_temp_to_cbin('aida64.zip', 'AIDA64') - - # Cleanup - remove_from_temp('aida64.zip') - -def update_autoruns(): - # Stop running processes - kill_process('Autoruns.exe') - kill_process('Autoruns64.exe') - - # Remove existing folders - remove_from_kit('Autoruns') - - # Download - download_to_temp('Autoruns.zip', SOURCE_URLS['Autoruns']) - - # Extract files - extract_temp_to_cbin('Autoruns.zip', 'Autoruns') - - # Cleanup - remove_from_temp('Autoruns.zip') - -def update_bleachbit(): - # Stop running processes - kill_process('bleachbit.exe') - - # Remove existing folders - remove_from_kit('BleachBit') - - # Download - download_to_temp('bleachbit.zip', SOURCE_URLS['BleachBit']) - download_to_temp('Winapp2.zip', SOURCE_URLS['Winapp2']) - - # Extract files - extract_temp_to_cbin('bleachbit.zip', 'BleachBit') - extract_generic( - r'{}\Winapp2.zip'.format(global_vars['TmpDir']), - r'{}\BleachBit\cleaners'.format(global_vars['CBinDir']), - mode='e', sz_args=[r'Winapp2-master\Non-CCleaner\Winapp2.ini']) - - # Move files into place - dest = r'{}\BleachBit'.format(global_vars['CBinDir']) - for item in os.scandir(r'{}\BleachBit-Portable'.format(dest)): - dest_item = '{}\{}'.format(dest, item.name) - if not os.path.exists(dest_item): - shutil.move(item.path, dest_item) - shutil.rmtree( - r'{}\BleachBit\BleachBit-Portable'.format(global_vars['CBinDir'])) - - # Cleanup - remove_from_temp('bleachbit.zip') - remove_from_temp('Winapp2.zip') - -def update_bluescreenview(): - # Stop running processes - for exe in ['BlueScreenView.exe', 'BlueScreenView64.exe']: - kill_process(exe) - - # Remove existing folders - remove_from_kit('BlueScreenView') - - # Download - download_to_temp('bluescreenview32.zip', SOURCE_URLS['BlueScreenView32']) - download_to_temp('bluescreenview64.zip', SOURCE_URLS['BlueScreenView64']) - - # Extract files - extract_temp_to_cbin('bluescreenview64.zip', 'BlueScreenView', sz_args=['BlueScreenView.exe']) - shutil.move( - r'{}\BlueScreenView\BlueScreenView.exe'.format(global_vars['CBinDir']), - r'{}\BlueScreenView\BlueScreenView64.exe'.format(global_vars['CBinDir'])) - extract_temp_to_cbin('bluescreenview32.zip', 'BlueScreenView') - - # Cleanup - remove_from_temp('bluescreenview32.zip') - remove_from_temp('bluescreenview64.zip') - -def update_erunt(): - # Stop running processes - kill_process('ERUNT.EXE') - - # Remove existing folders - remove_from_kit('ERUNT') - - # Download - download_to_temp('erunt.zip', SOURCE_URLS['ERUNT']) - - # Extract files - extract_temp_to_cbin('erunt.zip', 'ERUNT') - - # Cleanup - remove_from_temp('erunt.zip') - -def update_hitmanpro(): - # Stop running processes - for exe in ['HitmanPro.exe', 'HitmanPro64.exe']: - kill_process(exe) - - # Remove existing folders - remove_from_kit('HitmanPro') - - # Download - dest = r'{}\HitmanPro'.format(global_vars['CBinDir']) - download_generic(dest, 'HitmanPro.exe', SOURCE_URLS['HitmanPro32']) - download_generic(dest, 'HitmanPro64.exe', SOURCE_URLS['HitmanPro64']) - -def update_hwinfo(): - ## NOTE: Lives in .bin uncompressed - # Stop running processes - for exe in ['HWiNFO32.exe', 'HWiNFO64.exe']: - kill_process(exe) - - # Download - download_to_temp('HWiNFO32.zip', SOURCE_URLS['HWiNFO32']) - download_to_temp('HWiNFO64.zip', SOURCE_URLS['HWiNFO64']) - - # Extract files - extract_temp_to_bin('HWiNFO32.zip', 'HWiNFO') - extract_temp_to_bin('HWiNFO64.zip', 'HWiNFO') - - # Cleanup - remove_from_temp('HWiNFO32.zip') - remove_from_temp('HWiNFO64.zip') - -def update_produkey(): - # Stop running processes - for exe in ['ProduKey.exe', 'ProduKey64.exe']: - kill_process(exe) - - # Remove existing folders - remove_from_kit('ProduKey') - - # Download - download_to_temp('produkey32.zip', SOURCE_URLS['ProduKey32']) - download_to_temp('produkey64.zip', SOURCE_URLS['ProduKey64']) - - # Extract files - extract_temp_to_cbin('produkey64.zip', 'ProduKey', sz_args=['ProduKey.exe']) - shutil.move( - r'{}\ProduKey\ProduKey.exe'.format(global_vars['CBinDir']), - r'{}\ProduKey\ProduKey64.exe'.format(global_vars['CBinDir'])) - extract_temp_to_cbin('produkey32.zip', 'ProduKey') - - # Cleanup - remove_from_temp('produkey32.zip') - remove_from_temp('produkey64.zip') - -## Drivers ## -def update_intel_rst(): - # Remove existing folders - remove_from_kit('Intel RST') - - # Prep - dest = r'{}\_Drivers\Intel RST'.format(global_vars['CBinDir']) - include_path = r'{}\_include\_Drivers\Intel RST'.format( - global_vars['CBinDir']) - if os.path.exists(include_path): - shutil.copytree(include_path, dest) - - # Download - for name, url in RST_SOURCES.items(): - download_generic(dest, name, url) - -def update_intel_ssd_toolbox(): - # Remove existing folders - remove_from_kit('Intel SSD Toolbox.exe') - - # Download - download_generic( - r'{}\_Drivers\Intel SSD Toolbox'.format(global_vars['CBinDir']), - 'Intel SSD Toolbox.exe', - SOURCE_URLS['Intel SSD Toolbox']) - -def update_samsung_magician(): - # Remove existing folders - remove_from_kit('Samsung Magician.exe') - - # Download - download_generic( - r'{}\_Drivers\Samsung Magician'.format(global_vars['CBinDir']), - 'Samsung Magician.exe', - SOURCE_URLS['Samsung Magician']) - -def update_sdi_origin(): - # Download aria2 - download_to_temp('aria2.zip', SOURCE_URLS['aria2']) - aria_source = r'{}\aria2.zip'.format(global_vars['TmpDir']) - aria_dest = r'{}\aria2'.format(global_vars['TmpDir']) - aria = r'{}\aria2c.exe'.format(aria_dest) - extract_generic(aria_source, aria_dest, mode='e') - - # Prep for torrent download - download_to_temp('sdio.torrent', SOURCE_URLS['SDIO Torrent']) - sdio_torrent = r'{}\sdio.torrent'.format(global_vars['TmpDir']) - out = run_program([aria, sdio_torrent, '-S']) - indexes = [] - for line in out.stdout.decode().splitlines(): - r = re.search(r'^\s*(\d+)\|(.*)', line) - if r and not re.search(r'(\.(bat|inf)|Video|Server|Printer|XP)', line, re.IGNORECASE): - indexes.append(int(r.group(1))) - indexes = [str(i) for i in sorted(indexes)] - - # Download SDI Origin - cmd = [ - aria, - '--select-file={}'.format(','.join(indexes)), - '-d', aria_dest, - '--seed-time=0', - sdio_torrent, - '-new_console:n', '-new_console:s33V', - ] - run_program(cmd, pipe=False, check=False, shell=True) - sleep(1) - wait_for_process('aria2c') - - # Download SDI Origin extra themes - download_to_temp('sdio_themes.zip', SOURCE_URLS['SDIO Themes']) - theme_source = r'{}\sdio_themes.zip'.format(global_vars['TmpDir']) - theme_dest = r'{}\SDIO_Update\tools\SDI\themes'.format(aria_dest) - extract_generic(theme_source, theme_dest) - - # Move files into place - for item in os.scandir(r'{}\SDIO_Update'.format(aria_dest)): - dest_item = '{}\_Drivers\SDIO\{}'.format( - global_vars['BinDir'], item.name) - r = re.search(r'^SDIO_x?(64|)_?R.*exe$', item.name, re.IGNORECASE) - if r: - dest_item = dest_item.replace(item.name, 'SDIO{}.exe'.format( - r.group(1))) - if (not os.path.exists(dest_item) - and not re.search(r'\.(inf|bat)$', item.name, re.IGNORECASE)): - shutil.move(item.path, dest_item) - - # Cleanup - remove_from_temp('aria2') - remove_from_temp('aria2.zip') - remove_from_temp('sdio.torrent') - remove_from_temp('sdio_themes.zip') - -## Installers ## -def update_adobe_reader_dc(): - # Prep - dest = r'{}\.root_items\Installers\Extras\Office'.format( - global_vars['BaseDir']) - if os.path.exists(r'{}\Installers'.format(global_vars['BaseDir'])): - dest = dest.replace(r'\.root_items', '') - - # Remove existing folders - try: - os.remove(r'{}\Adobe Reader DC.exe'.format(dest)) - except FileNotFoundError: - pass - - # Download - download_generic( - dest, 'Adobe Reader DC.exe', SOURCE_URLS['Adobe Reader DC']) - -def update_office(): - # Remove existing folders - remove_from_kit('_Office') - - # Prep - dest = r'{}\_Office'.format(global_vars['CBinDir']) - include_path = r'{}\_include\_Office'.format(global_vars['CBinDir']) - if os.path.exists(include_path): - shutil.copytree(include_path, dest) - - # Download and extract - for year in ['2013', '2016']: - name = 'odt{}.exe'.format(year) - url = 'Office Deployment Tool {}'.format(year) - download_to_temp(name, SOURCE_URLS[url]) - cmd = [ - r'{}\odt{}.exe'.format(global_vars['TmpDir'], year), - r'/extract:{}\{}'.format(global_vars['TmpDir'], year), - '/quiet', - ] - run_program(cmd) - shutil.move( - r'{}\{}'.format(global_vars['TmpDir'], year), - r'{}\_Office\{}'.format(global_vars['CBinDir'], year)) - - # Cleanup - remove_from_temp('odt2013.exe') - remove_from_temp('odt2016.exe') - -def update_classic_start_skin(): - # Remove existing folders - remove_from_kit('ClassicStartSkin') - - # Download - download_generic( - r'{}\ClassicStartSkin'.format(global_vars['CBinDir']), - 'Metro-Win10-Black.skin7', - SOURCE_URLS['ClassicStartSkin']) - -def update_vcredists(): - # Remove existing folders - remove_from_kit('_vcredists') - - # Prep - dest = r'{}\_vcredists'.format(global_vars['CBinDir']) - include_path = r'{}\_include\_vcredists'.format(global_vars['CBinDir']) - if os.path.exists(include_path): - shutil.copytree(include_path, dest) - - # Download - for year in VCREDIST_SOURCES.keys(): - for bit in ['32', '64']: - dest = r'{}\_vcredists\{}\x{}'.format( - global_vars['CBinDir'], year, bit) - download_generic( - dest, - 'vcredist.exe', - VCREDIST_SOURCES[year][bit]) - -def update_one_ninite(section, dest, name, url, indent=8, width=40): - # Prep - url = 'https://ninite.com/{}/ninite.exe'.format(url) - - # Download - download_generic(out_dir=dest, out_name=name, source_url=url) - - # Copy to Installers folder - installer_parent = r'{}\Installers\Extras\{}'.format( - global_vars['BaseDir'], section) - installer_dest = r'{}\{}'.format(installer_parent, name) - os.makedirs(installer_parent, exist_ok=True) - if os.path.exists(installer_dest): - remove_item(installer_dest) - shutil.copy(r'{}\{}'.format(dest, name), installer_dest) - -def update_all_ninite(indent=8, width=40, other_results={}): - print_info('{}Ninite'.format(' '*int(indent/2))) - for section in sorted(NINITE_SOURCES.keys()): - print_success('{}{}'.format(' '*int(indent/4*3), section)) - dest = r'{}\_Ninite\{}'.format(global_vars['CBinDir'], section) - for name, url in sorted(NINITE_SOURCES[section].items()): - try_and_print(message=name, function=update_one_ninite, - other_results=other_results, indent=indent, width=width, - section=section, dest=dest, name=name, url=url) - -## Misc ## -def update_caffeine(): - # Stop running processes - kill_process('caffeine.exe') - - # Remove existing folders - remove_from_kit('Caffeine') - - # Download - download_to_temp('caffeine.zip', SOURCE_URLS['Caffeine']) - - # Extract files - extract_temp_to_cbin('caffeine.zip', 'Caffeine') - - # Cleanup - remove_from_temp('caffeine.zip') - -def update_du(): - # Stop running processes - kill_process('du.exe') - kill_process('du64.exe') - - # Remove existing folders - remove_from_kit('Du') - - # Download - download_to_temp('du.zip', SOURCE_URLS['Du']) - - # Extract files - extract_temp_to_cbin('du.zip', 'Du') - - # Cleanup - remove_from_temp('du.zip') - -def update_everything(): - # Stop running processes - for exe in ['Everything.exe', 'Everything64.exe']: - kill_process(exe) - - # Remove existing folders - remove_from_kit('Everything') - - # Download - download_to_temp('everything32.zip', SOURCE_URLS['Everything32']) - download_to_temp('everything64.zip', SOURCE_URLS['Everything64']) - - # Extract files - extract_temp_to_cbin('everything64.zip', 'Everything', sz_args=['Everything.exe']) - shutil.move( - r'{}\Everything\Everything.exe'.format(global_vars['CBinDir']), - r'{}\Everything\Everything64.exe'.format(global_vars['CBinDir'])) - extract_temp_to_cbin('everything32.zip', 'Everything') - - # Cleanup - remove_from_temp('everything32.zip') - remove_from_temp('everything64.zip') - -def update_firefox_ublock_origin(): - # Remove existing folders - remove_from_kit('FirefoxExtensions') - - # Download - download_to_temp('ff-uBO.xpi', SOURCE_URLS['Firefox uBO']) - - # Extract files - extract_generic( - r'{}\ff-uBO.xpi'.format(global_vars['TmpDir']), - r'{}\FirefoxExtensions\uBlock0@raymondhill.net'.format( - global_vars['CBinDir'])) - - # Cleanup - remove_from_temp('ff-uBO.xpi') - -def update_notepadplusplus(): - # Stop running processes - kill_process('notepadplusplus.exe') - - # Remove existing folders - remove_from_kit('NotepadPlusPlus') - - # Download - download_to_temp('npp.7z', SOURCE_URLS['NotepadPlusPlus']) - - # Extract files - extract_temp_to_cbin('npp.7z', 'NotepadPlusPlus') - shutil.move( - r'{}\NotepadPlusPlus\notepad++.exe'.format(global_vars['CBinDir']), - r'{}\NotepadPlusPlus\notepadplusplus.exe'.format(global_vars['CBinDir']) - ) - - # Cleanup - remove_from_temp('npp.7z') - -def update_putty(): - # Stop running processes - kill_process('PUTTY.EXE') - - # Remove existing folders - remove_from_kit('PuTTY') - - # Download - download_to_temp('putty.zip', SOURCE_URLS['PuTTY']) - - # Extract files - extract_temp_to_cbin('putty.zip', 'PuTTY') - - # Cleanup - remove_from_temp('putty.zip') - -def update_treesizefree(): - # Stop running processes - kill_process('TreeSizeFree.exe') - - # Remove existing folders - remove_from_kit('TreeSizeFree') - - # Download - download_to_temp( - 'treesizefree.zip.gz', SOURCE_URLS['TreeSizeFree']) - - # Extract files - ## NOTE: When downloaded using requests it is a .zip.gz? - source = r'{}\treesizefree.zip.gz'.format(global_vars['TmpDir']) - extract_generic(source, global_vars['TmpDir']) - extract_temp_to_cbin('treesizefree.zip', 'TreeSizeFree') - - # Cleanup - remove_from_temp('treesizefree.zip') - remove_from_temp('treesizefree.zip.gz') - -def update_xmplay(): - # Stop running processes - kill_process('xmplay.exe') - - # Remove existing folders - remove_from_kit('XMPlay') - - # Download - download_to_temp('xmplay.zip', SOURCE_URLS['XMPlay']) - download_to_temp('xmp-7z.zip', SOURCE_URLS['XMPlay 7z']) - download_to_temp('xmp-gme.zip', SOURCE_URLS['XMPlay Game']) - download_to_temp('xmp-rar.zip', SOURCE_URLS['XMPlay RAR']) - download_to_temp('WAModern.zip', SOURCE_URLS['XMPlay WAModern']) - - # Extract files - extract_temp_to_cbin('xmplay.zip', 'XMPlay', - mode='e', sz_args=['xmplay.exe', 'xmplay.txt']) - for item in ['xmp-7z', 'xmp-gme', 'xmp-rar', 'WAModern']: - filter = [] - if item == 'WAModern': - filter.append('WAModern NightVision.xmpskin') - extract_generic( - r'{}\{}.zip'.format(global_vars['TmpDir'], item), - r'{}\XMPlay\plugins'.format(global_vars['CBinDir']), - mode='e', sz_args=filter) - - # Download Music - dest = r'{}\XMPlay\music_tmp\MOD'.format(global_vars['CBinDir']) - for mod in MUSIC_MOD: - name = mod.split('#')[-1] - url = 'https://api.modarchive.org/downloads.php?moduleid={}'.format(mod) - download_generic(dest, name, url) - dest = r'{}\XMPlay\music_tmp\SNES'.format(global_vars['CBinDir']) - for game in MUSIC_SNES: - name = '{}.rsn'.format(game) - url = 'http://snesmusic.org/v2/download.php?spcNow={}'.format(game) - download_generic(dest, name, url) - - # Compress Music - cmd = [ - global_vars['Tools']['SevenZip'], - 'a', r'{}\XMPlay\music.7z'.format(global_vars['CBinDir']), - '-t7z', '-mx=9', '-bso0', '-bse0', - r'{}\XMPlay\music_tmp\*'.format(global_vars['CBinDir']), - ] - run_program(cmd) - - # Cleanup - remove_item(r'{}\XMPlay\music_tmp'.format(global_vars['CBinDir'])) - remove_from_temp('xmplay.zip') - remove_from_temp('xmp-7z.zip') - remove_from_temp('xmp-gme.zip') - remove_from_temp('xmp-rar.zip') - remove_from_temp('WAModern.zip') - -## Repairs ## -def update_adwcleaner(): - # Stop running processes - kill_process('AdwCleaner.exe') - - # Remove existing folders - remove_from_kit('AdwCleaner') - - # Download - url = resolve_dynamic_url( - SOURCE_URLS['AdwCleaner'], - 'id="downloadLink"') - download_generic( - r'{}\AdwCleaner'.format(global_vars['CBinDir']), 'AdwCleaner.exe', url) - -def update_kvrt(): - # Stop running processes - kill_process('KVRT.exe') - - # Remove existing folders - remove_from_kit('KVRT') - - # Download - download_generic( - r'{}\KVRT'.format(global_vars['CBinDir']), - 'KVRT.exe', - SOURCE_URLS['KVRT']) - -def update_rkill(): - # Stop running processes - kill_process('RKill.exe') - - # Remove existing folders - remove_from_kit('RKill') - - # Download - url = resolve_dynamic_url( - SOURCE_URLS['RKill'], - 'href.*rkill\.exe') - download_generic( - r'{}\RKill'.format(global_vars['CBinDir']), 'RKill.exe', url) - -def update_tdsskiller(): - # Stop running processes - kill_process('TDSSKiller.exe') - - # Remove existing folders - remove_from_kit('TDSSKiller') - - # Download - download_generic( - r'{}\TDSSKiller'.format(global_vars['CBinDir']), - 'TDSSKiller.exe', - SOURCE_URLS['TDSSKiller']) - -## Uninstallers ## -def update_iobit_uninstaller(): - # Stop running processes - kill_process('IObitUninstallerPortable.exe') - - # Remove existing folders - remove_from_kit('IObitUninstallerPortable') - - # Download - download_generic( - global_vars['CBinDir'], - 'IObitUninstallerPortable.exe', - SOURCE_URLS['IOBit_Uninstaller']) - - # "Install" - cmd = r'{}\IObitUninstallerPortable.exe'.format(global_vars['CBinDir']) - popen_program(cmd) - sleep(1) - wait_for_process('IObitUninstallerPortable') - - # Cleanup - remove_from_kit('IObitUninstallerPortable.exe') - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Functions - Build / Update + +import requests + +from functions.common import * +from functions.data import * +from settings.launchers import * +from settings.music import * +from settings.sources import * + +def compress_and_remove_item(item): + try: + compress_item(item) + except: + raise GenericError + else: + remove_item(item.path) + +def compress_item(item): + # Prep + prev_dir = os.getcwd() + dest = '{}.7z'.format(item.path) + wd = item.path + include_str = '*' + if os.path.isfile(wd): + wd = os.path.abspath(r'{}\{}'.format(wd, os.path.pardir)) + include_str = item.name + os.chdir(wd) + + # Compress + cmd = [ + global_vars['Tools']['SevenZip'], + 'a', dest, + '-t7z', '-mx=7', '-myx=7', '-ms=on', '-mhe', '-bso0', '-bse0', + '-p{}'.format(ARCHIVE_PASSWORD), + include_str, + ] + run_program(cmd) + + # Done + os.chdir(prev_dir) + +def download_generic(out_dir, out_name, source_url): + """Downloads a file using requests.""" + ## Code based on this Q&A: https://stackoverflow.com/q/16694907 + ### Asked by: https://stackoverflow.com/users/427457/roman-podlinov + ### Edited by: https://stackoverflow.com/users/657427/christophe-roussy + ### Using answer: https://stackoverflow.com/a/39217788 + ### Answer from: https://stackoverflow.com/users/4323/john-zwinck + os.makedirs(out_dir, exist_ok=True) + out_path = '{}/{}'.format(out_dir, out_name) + try: + r = requests.get(source_url, stream=True) + with open(out_path, 'wb') as f: + shutil.copyfileobj(r.raw, f) + r.close() + except: + raise GenericError('Failed to download file.') + +def download_to_temp(out_name, source_url): + download_generic(global_vars['TmpDir'], out_name, source_url) + +def extract_generic(source, dest, mode='x', sz_args=[]): + cmd = [ + global_vars['Tools']['SevenZip'], + mode, source, r'-o{}'.format(dest), + '-aoa', '-bso0', '-bse0', + ] + cmd.extend(sz_args) + run_program(cmd) + +def extract_temp_to_bin(source, item, mode='x', sz_args=[]): + source = r'{}\{}'.format(global_vars['TmpDir'], source) + dest = r'{}\{}'.format(global_vars['BinDir'], item) + extract_generic(source, dest, mode, sz_args) + +def extract_temp_to_cbin(source, item, mode='x', sz_args=[]): + source = r'{}\{}'.format(global_vars['TmpDir'], source) + dest = r'{}\{}'.format(global_vars['CBinDir'], item) + include_path = r'{}\_include\{}'.format(global_vars['CBinDir'], item) + if os.path.exists(include_path): + shutil.copytree(include_path, dest) + extract_generic(source, dest, mode, sz_args) + +def generate_launcher(section, name, options): + # Prep + dest = r'{}\{}'.format(global_vars['BaseDir'], section) + if section == '(Root)': + dest = global_vars['BaseDir'] + full_path = r'{}\{}.cmd'.format(dest, name) + template = r'{}\Scripts\Launcher_Template.cmd'.format(global_vars['BinDir']) + + # Format options + f_options = {} + for opt in options.keys(): + # Values need to be a list to support the multi-line extra code sections + if opt == 'Extra Code': + f_options['rem EXTRA_CODE'] = options['Extra Code'] + elif re.search(r'^L_\w+', opt, re.IGNORECASE): + new_opt = 'set {}='.format(opt) + f_options[new_opt] = ['set {}={}'.format(opt, options[opt])] + + # Read template and update using f_options + out_text = [] + with open(template, 'r') as f: + for line in f.readlines(): + # Strip all lines to let Python handle/correct the CRLF endings + line = line.strip() + if line in f_options: + # Extend instead of append to support extra code sections + out_text.extend(f_options[line]) + else: + out_text.append(line) + + # Write file + os.makedirs(dest, exist_ok=True) + with open(full_path, 'w') as f: + # f.writelines(out_text) + f.write('\n'.join(out_text)) + +def remove_item(item_path): + if os.path.exists(item_path): + if os.path.isdir(item_path): + shutil.rmtree(item_path, ignore_errors=True) + else: + os.remove(item_path) + +def remove_from_kit(item): + item_locations = [] + for p in [global_vars['BinDir'], global_vars['CBinDir']]: + item_locations.append(r'{}\{}'.format(p, item)) + item_locations.append(r'{}\_Drivers\{}'.format(p, item)) + for item_path in item_locations: + remove_item(item_path) + +def remove_from_temp(item): + item_path = r'{}\{}'.format(global_vars['TmpDir'], item) + remove_item(item_path) + +def resolve_dynamic_url(source_url, regex): + """Scan source_url for a url using the regex provided; returns str.""" + # Load the download page + try: + download_page = requests.get(source_url) + except Exception: + # "Fail silently as the download_to_temp() function will catch it + return None + + # Scan for the url using the regex provided + url = None + for line in download_page.content.decode().splitlines(): + if re.search(regex, line): + url = line.strip() + url = re.sub(r'.*(a |)href="([^"]+)".*', r'\2', url) + url = re.sub(r".*(a |)href='([^']+)'.*", r'\2', url) + break + + # Return + return url + +def scan_for_net_installers(server, family_name, min_year): + if not server['Mounted']: + mount_network_share(server) + + if server['Mounted']: + for year in os.scandir(r'\\{IP}\{Share}'.format(**server)): + if int(year.name) < min_year: + # Don't support outdated installers + continue + for version in os.scandir(year.path): + section = r'Installers\Extras\{}\{}'.format( + family_name, year.name) + if section not in LAUNCHERS: + LAUNCHERS[section] = {} + name = version.name + if re.search(r'(exe|msi)$', name, re.IGNORECASE): + name = name[:-4] + if name not in LAUNCHERS[section]: + LAUNCHERS[section][name] = { + 'L_TYPE': family_name, + 'L_PATH': year.name, + 'L_ITEM': version.name, + } + umount_network_share(server) + +## Data Recovery ## +def update_testdisk(): + # Stop running processes + for exe in ['fidentify_win.exe', 'photorec_win.exe', + 'qphotorec_win.exe', 'testdisk_win.exe']: + kill_process(exe) + + # Remove existing folders + remove_from_kit('TestDisk') + + # Download + download_to_temp('testdisk_wip.zip', SOURCE_URLS['TestDisk']) + + # Extract files + extract_temp_to_cbin('testdisk_wip.zip', 'TestDisk') + dest = r'{}\TestDisk'.format(global_vars['CBinDir']) + for item in os.scandir(r'{}\testdisk-7.1-WIP'.format(dest)): + dest_item = '{}\{}'.format(dest, item.name) + if not os.path.exists(dest_item): + shutil.move(item.path, dest_item) + shutil.rmtree( + r'{}\TestDisk\testdisk-7.1-WIP'.format(global_vars['CBinDir'])) + + # Cleanup + remove_from_temp('testdisk_wip.zip') + +## Data Transfers ## +def update_fastcopy(): + ## NOTE: Lives in .bin uncompressed + # Stop running processes + for process in ['FastCopy.exe', 'FastCopy64.exe']: + kill_process(process) + + # Remove existing folders + remove_from_kit('FastCopy') + + # Download + download_to_temp('FastCopy32.zip', SOURCE_URLS['FastCopy32']) + download_to_temp('FastCopy64.zip', SOURCE_URLS['FastCopy64']) + + # Extract + extract_temp_to_bin('FastCopy64.zip', 'FastCopy', sz_args=['FastCopy.exe']) + shutil.move( + r'{}\FastCopy\FastCopy.exe'.format(global_vars['BinDir']), + r'{}\FastCopy\FastCopy64.exe'.format(global_vars['BinDir'])) + extract_temp_to_bin('FastCopy32.zip', 'FastCopy', sz_args=[r'-x!setup.exe', r'-x!*.dll']) + + # Cleanup + remove_from_temp('FastCopy32.zip') + remove_from_temp('FastCopy64.zip') + +def update_wimlib(): + # Stop running processes + kill_process('wimlib-imagex.exe') + + # Remove existing folders + remove_from_kit('wimlib') + + # Download + download_to_temp('wimlib32.zip', SOURCE_URLS['wimlib32']) + download_to_temp('wimlib64.zip', SOURCE_URLS['wimlib64']) + + # Extract + extract_generic( + r'{}\wimlib32.zip'.format(global_vars['TmpDir']), + r'{}\wimlib\x32'.format(global_vars['CBinDir'])) + extract_generic( + r'{}\wimlib64.zip'.format(global_vars['TmpDir']), + r'{}\wimlib\x64'.format(global_vars['CBinDir'])) + + # Cleanup + remove_from_temp('wimlib32.zip') + remove_from_temp('wimlib64.zip') + +def update_xyplorer(): + # Stop running processes + kill_process('XYplorerFree.exe') + + # Remove existing folders + remove_from_kit('XYplorerFree') + + # Download + download_to_temp('xyplorer_free.zip', SOURCE_URLS['XYplorerFree']) + + # Extract files + extract_temp_to_cbin('xyplorer_free.zip', 'XYplorerFree') + + # Cleanup + remove_from_temp('xyplorer_free.zip') + +## Diagnostics ## +def update_aida64(): + # Stop running processes + kill_process('notepadplusplus.exe') + + # Remove existing folders + remove_from_kit('AIDA64') + + # Download + download_to_temp('aida64.zip', SOURCE_URLS['AIDA64']) + + # Extract files + extract_temp_to_cbin('aida64.zip', 'AIDA64') + + # Cleanup + remove_from_temp('aida64.zip') + +def update_autoruns(): + # Stop running processes + kill_process('Autoruns.exe') + kill_process('Autoruns64.exe') + + # Remove existing folders + remove_from_kit('Autoruns') + + # Download + download_to_temp('Autoruns.zip', SOURCE_URLS['Autoruns']) + + # Extract files + extract_temp_to_cbin('Autoruns.zip', 'Autoruns') + + # Cleanup + remove_from_temp('Autoruns.zip') + +def update_bleachbit(): + # Stop running processes + kill_process('bleachbit.exe') + + # Remove existing folders + remove_from_kit('BleachBit') + + # Download + download_to_temp('bleachbit.zip', SOURCE_URLS['BleachBit']) + download_to_temp('Winapp2.zip', SOURCE_URLS['Winapp2']) + + # Extract files + extract_temp_to_cbin('bleachbit.zip', 'BleachBit') + extract_generic( + r'{}\Winapp2.zip'.format(global_vars['TmpDir']), + r'{}\BleachBit\cleaners'.format(global_vars['CBinDir']), + mode='e', sz_args=[r'Winapp2-master\Non-CCleaner\Winapp2.ini']) + + # Move files into place + dest = r'{}\BleachBit'.format(global_vars['CBinDir']) + for item in os.scandir(r'{}\BleachBit-Portable'.format(dest)): + dest_item = '{}\{}'.format(dest, item.name) + if not os.path.exists(dest_item): + shutil.move(item.path, dest_item) + shutil.rmtree( + r'{}\BleachBit\BleachBit-Portable'.format(global_vars['CBinDir'])) + + # Cleanup + remove_from_temp('bleachbit.zip') + remove_from_temp('Winapp2.zip') + +def update_bluescreenview(): + # Stop running processes + for exe in ['BlueScreenView.exe', 'BlueScreenView64.exe']: + kill_process(exe) + + # Remove existing folders + remove_from_kit('BlueScreenView') + + # Download + download_to_temp('bluescreenview32.zip', SOURCE_URLS['BlueScreenView32']) + download_to_temp('bluescreenview64.zip', SOURCE_URLS['BlueScreenView64']) + + # Extract files + extract_temp_to_cbin('bluescreenview64.zip', 'BlueScreenView', sz_args=['BlueScreenView.exe']) + shutil.move( + r'{}\BlueScreenView\BlueScreenView.exe'.format(global_vars['CBinDir']), + r'{}\BlueScreenView\BlueScreenView64.exe'.format(global_vars['CBinDir'])) + extract_temp_to_cbin('bluescreenview32.zip', 'BlueScreenView') + + # Cleanup + remove_from_temp('bluescreenview32.zip') + remove_from_temp('bluescreenview64.zip') + +def update_erunt(): + # Stop running processes + kill_process('ERUNT.EXE') + + # Remove existing folders + remove_from_kit('ERUNT') + + # Download + download_to_temp('erunt.zip', SOURCE_URLS['ERUNT']) + + # Extract files + extract_temp_to_cbin('erunt.zip', 'ERUNT') + + # Cleanup + remove_from_temp('erunt.zip') + +def update_hitmanpro(): + # Stop running processes + for exe in ['HitmanPro.exe', 'HitmanPro64.exe']: + kill_process(exe) + + # Remove existing folders + remove_from_kit('HitmanPro') + + # Download + dest = r'{}\HitmanPro'.format(global_vars['CBinDir']) + download_generic(dest, 'HitmanPro.exe', SOURCE_URLS['HitmanPro32']) + download_generic(dest, 'HitmanPro64.exe', SOURCE_URLS['HitmanPro64']) + +def update_hwinfo(): + ## NOTE: Lives in .bin uncompressed + # Stop running processes + for exe in ['HWiNFO32.exe', 'HWiNFO64.exe']: + kill_process(exe) + + # Download + download_to_temp('HWiNFO32.zip', SOURCE_URLS['HWiNFO32']) + download_to_temp('HWiNFO64.zip', SOURCE_URLS['HWiNFO64']) + + # Extract files + extract_temp_to_bin('HWiNFO32.zip', 'HWiNFO') + extract_temp_to_bin('HWiNFO64.zip', 'HWiNFO') + + # Cleanup + remove_from_temp('HWiNFO32.zip') + remove_from_temp('HWiNFO64.zip') + +def update_produkey(): + # Stop running processes + for exe in ['ProduKey.exe', 'ProduKey64.exe']: + kill_process(exe) + + # Remove existing folders + remove_from_kit('ProduKey') + + # Download + download_to_temp('produkey32.zip', SOURCE_URLS['ProduKey32']) + download_to_temp('produkey64.zip', SOURCE_URLS['ProduKey64']) + + # Extract files + extract_temp_to_cbin('produkey64.zip', 'ProduKey', sz_args=['ProduKey.exe']) + shutil.move( + r'{}\ProduKey\ProduKey.exe'.format(global_vars['CBinDir']), + r'{}\ProduKey\ProduKey64.exe'.format(global_vars['CBinDir'])) + extract_temp_to_cbin('produkey32.zip', 'ProduKey') + + # Cleanup + remove_from_temp('produkey32.zip') + remove_from_temp('produkey64.zip') + +## Drivers ## +def update_intel_rst(): + # Remove existing folders + remove_from_kit('Intel RST') + + # Prep + dest = r'{}\_Drivers\Intel RST'.format(global_vars['CBinDir']) + include_path = r'{}\_include\_Drivers\Intel RST'.format( + global_vars['CBinDir']) + if os.path.exists(include_path): + shutil.copytree(include_path, dest) + + # Download + for name, url in RST_SOURCES.items(): + download_generic(dest, name, url) + +def update_intel_ssd_toolbox(): + # Remove existing folders + remove_from_kit('Intel SSD Toolbox.exe') + + # Download + download_generic( + r'{}\_Drivers\Intel SSD Toolbox'.format(global_vars['CBinDir']), + 'Intel SSD Toolbox.exe', + SOURCE_URLS['Intel SSD Toolbox']) + +def update_samsung_magician(): + # Remove existing folders + remove_from_kit('Samsung Magician.exe') + + # Download + download_generic( + r'{}\_Drivers\Samsung Magician'.format(global_vars['CBinDir']), + 'Samsung Magician.exe', + SOURCE_URLS['Samsung Magician']) + +def update_sdi_origin(): + # Download aria2 + download_to_temp('aria2.zip', SOURCE_URLS['aria2']) + aria_source = r'{}\aria2.zip'.format(global_vars['TmpDir']) + aria_dest = r'{}\aria2'.format(global_vars['TmpDir']) + aria = r'{}\aria2c.exe'.format(aria_dest) + extract_generic(aria_source, aria_dest, mode='e') + + # Prep for torrent download + download_to_temp('sdio.torrent', SOURCE_URLS['SDIO Torrent']) + sdio_torrent = r'{}\sdio.torrent'.format(global_vars['TmpDir']) + out = run_program([aria, sdio_torrent, '-S']) + indexes = [] + for line in out.stdout.decode().splitlines(): + r = re.search(r'^\s*(\d+)\|(.*)', line) + if r and not re.search(r'(\.(bat|inf)|Video|Server|Printer|XP)', line, re.IGNORECASE): + indexes.append(int(r.group(1))) + indexes = [str(i) for i in sorted(indexes)] + + # Download SDI Origin + cmd = [ + aria, + '--select-file={}'.format(','.join(indexes)), + '-d', aria_dest, + '--seed-time=0', + sdio_torrent, + '-new_console:n', '-new_console:s33V', + ] + run_program(cmd, pipe=False, check=False, shell=True) + sleep(1) + wait_for_process('aria2c') + + # Download SDI Origin extra themes + download_to_temp('sdio_themes.zip', SOURCE_URLS['SDIO Themes']) + theme_source = r'{}\sdio_themes.zip'.format(global_vars['TmpDir']) + theme_dest = r'{}\SDIO_Update\tools\SDI\themes'.format(aria_dest) + extract_generic(theme_source, theme_dest) + + # Move files into place + for item in os.scandir(r'{}\SDIO_Update'.format(aria_dest)): + dest_item = '{}\_Drivers\SDIO\{}'.format( + global_vars['BinDir'], item.name) + r = re.search(r'^SDIO_x?(64|)_?R.*exe$', item.name, re.IGNORECASE) + if r: + dest_item = dest_item.replace(item.name, 'SDIO{}.exe'.format( + r.group(1))) + if (not os.path.exists(dest_item) + and not re.search(r'\.(inf|bat)$', item.name, re.IGNORECASE)): + shutil.move(item.path, dest_item) + + # Cleanup + remove_from_temp('aria2') + remove_from_temp('aria2.zip') + remove_from_temp('sdio.torrent') + remove_from_temp('sdio_themes.zip') + +## Installers ## +def update_adobe_reader_dc(): + # Prep + dest = r'{}\.root_items\Installers\Extras\Office'.format( + global_vars['BaseDir']) + if os.path.exists(r'{}\Installers'.format(global_vars['BaseDir'])): + dest = dest.replace(r'\.root_items', '') + + # Remove existing folders + try: + os.remove(r'{}\Adobe Reader DC.exe'.format(dest)) + except FileNotFoundError: + pass + + # Download + download_generic( + dest, 'Adobe Reader DC.exe', SOURCE_URLS['Adobe Reader DC']) + +def update_office(): + # Remove existing folders + remove_from_kit('_Office') + + # Prep + dest = r'{}\_Office'.format(global_vars['CBinDir']) + include_path = r'{}\_include\_Office'.format(global_vars['CBinDir']) + if os.path.exists(include_path): + shutil.copytree(include_path, dest) + + # Download and extract + for year in ['2013', '2016']: + name = 'odt{}.exe'.format(year) + url = 'Office Deployment Tool {}'.format(year) + download_to_temp(name, SOURCE_URLS[url]) + cmd = [ + r'{}\odt{}.exe'.format(global_vars['TmpDir'], year), + r'/extract:{}\{}'.format(global_vars['TmpDir'], year), + '/quiet', + ] + run_program(cmd) + shutil.move( + r'{}\{}'.format(global_vars['TmpDir'], year), + r'{}\_Office\{}'.format(global_vars['CBinDir'], year)) + + # Cleanup + remove_from_temp('odt2013.exe') + remove_from_temp('odt2016.exe') + +def update_classic_start_skin(): + # Remove existing folders + remove_from_kit('ClassicStartSkin') + + # Download + download_generic( + r'{}\ClassicStartSkin'.format(global_vars['CBinDir']), + 'Metro-Win10-Black.skin7', + SOURCE_URLS['ClassicStartSkin']) + +def update_vcredists(): + # Remove existing folders + remove_from_kit('_vcredists') + + # Prep + dest = r'{}\_vcredists'.format(global_vars['CBinDir']) + include_path = r'{}\_include\_vcredists'.format(global_vars['CBinDir']) + if os.path.exists(include_path): + shutil.copytree(include_path, dest) + + # Download + for year in VCREDIST_SOURCES.keys(): + for bit in ['32', '64']: + dest = r'{}\_vcredists\{}\x{}'.format( + global_vars['CBinDir'], year, bit) + download_generic( + dest, + 'vcredist.exe', + VCREDIST_SOURCES[year][bit]) + +def update_one_ninite(section, dest, name, url, indent=8, width=40): + # Prep + url = 'https://ninite.com/{}/ninite.exe'.format(url) + + # Download + download_generic(out_dir=dest, out_name=name, source_url=url) + + # Copy to Installers folder + installer_parent = r'{}\Installers\Extras\{}'.format( + global_vars['BaseDir'], section) + installer_dest = r'{}\{}'.format(installer_parent, name) + os.makedirs(installer_parent, exist_ok=True) + if os.path.exists(installer_dest): + remove_item(installer_dest) + shutil.copy(r'{}\{}'.format(dest, name), installer_dest) + +def update_all_ninite(indent=8, width=40, other_results={}): + print_info('{}Ninite'.format(' '*int(indent/2))) + for section in sorted(NINITE_SOURCES.keys()): + print_success('{}{}'.format(' '*int(indent/4*3), section)) + dest = r'{}\_Ninite\{}'.format(global_vars['CBinDir'], section) + for name, url in sorted(NINITE_SOURCES[section].items()): + try_and_print(message=name, function=update_one_ninite, + other_results=other_results, indent=indent, width=width, + section=section, dest=dest, name=name, url=url) + +## Misc ## +def update_caffeine(): + # Stop running processes + kill_process('caffeine.exe') + + # Remove existing folders + remove_from_kit('Caffeine') + + # Download + download_to_temp('caffeine.zip', SOURCE_URLS['Caffeine']) + + # Extract files + extract_temp_to_cbin('caffeine.zip', 'Caffeine') + + # Cleanup + remove_from_temp('caffeine.zip') + +def update_du(): + # Stop running processes + kill_process('du.exe') + kill_process('du64.exe') + + # Remove existing folders + remove_from_kit('Du') + + # Download + download_to_temp('du.zip', SOURCE_URLS['Du']) + + # Extract files + extract_temp_to_cbin('du.zip', 'Du') + + # Cleanup + remove_from_temp('du.zip') + +def update_everything(): + # Stop running processes + for exe in ['Everything.exe', 'Everything64.exe']: + kill_process(exe) + + # Remove existing folders + remove_from_kit('Everything') + + # Download + download_to_temp('everything32.zip', SOURCE_URLS['Everything32']) + download_to_temp('everything64.zip', SOURCE_URLS['Everything64']) + + # Extract files + extract_temp_to_cbin('everything64.zip', 'Everything', sz_args=['Everything.exe']) + shutil.move( + r'{}\Everything\Everything.exe'.format(global_vars['CBinDir']), + r'{}\Everything\Everything64.exe'.format(global_vars['CBinDir'])) + extract_temp_to_cbin('everything32.zip', 'Everything') + + # Cleanup + remove_from_temp('everything32.zip') + remove_from_temp('everything64.zip') + +def update_firefox_ublock_origin(): + # Remove existing folders + remove_from_kit('FirefoxExtensions') + + # Download + download_to_temp('ff-uBO.xpi', SOURCE_URLS['Firefox uBO']) + + # Extract files + extract_generic( + r'{}\ff-uBO.xpi'.format(global_vars['TmpDir']), + r'{}\FirefoxExtensions\uBlock0@raymondhill.net'.format( + global_vars['CBinDir'])) + + # Cleanup + remove_from_temp('ff-uBO.xpi') + +def update_notepadplusplus(): + # Stop running processes + kill_process('notepadplusplus.exe') + + # Remove existing folders + remove_from_kit('NotepadPlusPlus') + + # Download + download_to_temp('npp.7z', SOURCE_URLS['NotepadPlusPlus']) + + # Extract files + extract_temp_to_cbin('npp.7z', 'NotepadPlusPlus') + shutil.move( + r'{}\NotepadPlusPlus\notepad++.exe'.format(global_vars['CBinDir']), + r'{}\NotepadPlusPlus\notepadplusplus.exe'.format(global_vars['CBinDir']) + ) + + # Cleanup + remove_from_temp('npp.7z') + +def update_putty(): + # Stop running processes + kill_process('PUTTY.EXE') + + # Remove existing folders + remove_from_kit('PuTTY') + + # Download + download_to_temp('putty.zip', SOURCE_URLS['PuTTY']) + + # Extract files + extract_temp_to_cbin('putty.zip', 'PuTTY') + + # Cleanup + remove_from_temp('putty.zip') + +def update_treesizefree(): + # Stop running processes + kill_process('TreeSizeFree.exe') + + # Remove existing folders + remove_from_kit('TreeSizeFree') + + # Download + download_to_temp( + 'treesizefree.zip.gz', SOURCE_URLS['TreeSizeFree']) + + # Extract files + ## NOTE: When downloaded using requests it is a .zip.gz? + source = r'{}\treesizefree.zip.gz'.format(global_vars['TmpDir']) + extract_generic(source, global_vars['TmpDir']) + extract_temp_to_cbin('treesizefree.zip', 'TreeSizeFree') + + # Cleanup + remove_from_temp('treesizefree.zip') + remove_from_temp('treesizefree.zip.gz') + +def update_xmplay(): + # Stop running processes + kill_process('xmplay.exe') + + # Remove existing folders + remove_from_kit('XMPlay') + + # Download + download_to_temp('xmplay.zip', SOURCE_URLS['XMPlay']) + download_to_temp('xmp-7z.zip', SOURCE_URLS['XMPlay 7z']) + download_to_temp('xmp-gme.zip', SOURCE_URLS['XMPlay Game']) + download_to_temp('xmp-rar.zip', SOURCE_URLS['XMPlay RAR']) + download_to_temp('WAModern.zip', SOURCE_URLS['XMPlay WAModern']) + + # Extract files + extract_temp_to_cbin('xmplay.zip', 'XMPlay', + mode='e', sz_args=['xmplay.exe', 'xmplay.txt']) + for item in ['xmp-7z', 'xmp-gme', 'xmp-rar', 'WAModern']: + filter = [] + if item == 'WAModern': + filter.append('WAModern NightVision.xmpskin') + extract_generic( + r'{}\{}.zip'.format(global_vars['TmpDir'], item), + r'{}\XMPlay\plugins'.format(global_vars['CBinDir']), + mode='e', sz_args=filter) + + # Download Music + dest = r'{}\XMPlay\music_tmp\MOD'.format(global_vars['CBinDir']) + for mod in MUSIC_MOD: + name = mod.split('#')[-1] + url = 'https://api.modarchive.org/downloads.php?moduleid={}'.format(mod) + download_generic(dest, name, url) + dest = r'{}\XMPlay\music_tmp\SNES'.format(global_vars['CBinDir']) + for game in MUSIC_SNES: + name = '{}.rsn'.format(game) + url = 'http://snesmusic.org/v2/download.php?spcNow={}'.format(game) + download_generic(dest, name, url) + + # Compress Music + cmd = [ + global_vars['Tools']['SevenZip'], + 'a', r'{}\XMPlay\music.7z'.format(global_vars['CBinDir']), + '-t7z', '-mx=9', '-bso0', '-bse0', + r'{}\XMPlay\music_tmp\*'.format(global_vars['CBinDir']), + ] + run_program(cmd) + + # Cleanup + remove_item(r'{}\XMPlay\music_tmp'.format(global_vars['CBinDir'])) + remove_from_temp('xmplay.zip') + remove_from_temp('xmp-7z.zip') + remove_from_temp('xmp-gme.zip') + remove_from_temp('xmp-rar.zip') + remove_from_temp('WAModern.zip') + +## Repairs ## +def update_adwcleaner(): + # Stop running processes + kill_process('AdwCleaner.exe') + + # Remove existing folders + remove_from_kit('AdwCleaner') + + # Download + url = resolve_dynamic_url( + SOURCE_URLS['AdwCleaner'], + 'id="downloadLink"') + download_generic( + r'{}\AdwCleaner'.format(global_vars['CBinDir']), 'AdwCleaner.exe', url) + +def update_kvrt(): + # Stop running processes + kill_process('KVRT.exe') + + # Remove existing folders + remove_from_kit('KVRT') + + # Download + download_generic( + r'{}\KVRT'.format(global_vars['CBinDir']), + 'KVRT.exe', + SOURCE_URLS['KVRT']) + +def update_rkill(): + # Stop running processes + kill_process('RKill.exe') + + # Remove existing folders + remove_from_kit('RKill') + + # Download + url = resolve_dynamic_url( + SOURCE_URLS['RKill'], + 'href.*rkill\.exe') + download_generic( + r'{}\RKill'.format(global_vars['CBinDir']), 'RKill.exe', url) + +def update_tdsskiller(): + # Stop running processes + kill_process('TDSSKiller.exe') + + # Remove existing folders + remove_from_kit('TDSSKiller') + + # Download + download_generic( + r'{}\TDSSKiller'.format(global_vars['CBinDir']), + 'TDSSKiller.exe', + SOURCE_URLS['TDSSKiller']) + +## Uninstallers ## +def update_iobit_uninstaller(): + # Stop running processes + kill_process('IObitUninstallerPortable.exe') + + # Remove existing folders + remove_from_kit('IObitUninstallerPortable') + + # Download + download_generic( + global_vars['CBinDir'], + 'IObitUninstallerPortable.exe', + SOURCE_URLS['IOBit_Uninstaller']) + + # "Install" + cmd = r'{}\IObitUninstallerPortable.exe'.format(global_vars['CBinDir']) + popen_program(cmd) + sleep(1) + wait_for_process('IObitUninstallerPortable') + + # Cleanup + remove_from_kit('IObitUninstallerPortable.exe') + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/init_client_dir.cmd b/.bin/Scripts/init_client_dir.cmd index 0cc973cf..952624a0 100644 --- a/.bin/Scripts/init_client_dir.cmd +++ b/.bin/Scripts/init_client_dir.cmd @@ -1,78 +1,78 @@ -:: Wizard Kit: Create client_dir folder(s) - -@echo off -if defined DEBUG (@echo on) - -:SafetyCheck -if not defined bin (goto Abort) - -:Init -set "SETTINGS=%bin%\Scripts\settings\main.py" -for /f "tokens=* usebackq" %%f in (`findstr KIT_NAME_SHORT %SETTINGS%`) do ( - set "_v=%%f" - set "_v=!_v:*'=!" - set "KIT_NAME_SHORT=!_v:~0,-1!" -) -set "client_dir=%systemdrive%\%KIT_NAME_SHORT%" -set "log_dir=%client_dir%\Info\%iso_date%" - -:Flags -set _backups= -set _info= -set _office= -set _quarantine= -set _quickbooks= -set _transfer= -for %%f in (%*) do ( - if /i "%%f" == "/DEBUG" (@echo on) - if /i "%%f" == "/Backups" set _backups=True - if /i "%%f" == "/Info" set _info=True - if /i "%%f" == "/Office" set _office=True - if /i "%%f" == "/Quarantine" set _quarantine=True - if /i "%%f" == "/QuickBooks" set _quickbooks=True - if /i "%%f" == "/Transfer" set _transfer=True -) - -:GetDate -:: Credit to SS64.com Code taken from http://ss64.com/nt/syntax-getdate.html -:: Use WMIC to retrieve date and time in ISO 8601 format. -for /f "skip=1 tokens=1-6" %%G in ('WMIC Path Win32_LocalTime Get Day^,Hour^,Minute^,Month^,Second^,Year /Format:table') do ( - if "%%~L"=="" goto s_done - set _yyyy=%%L - set _mm=00%%J - set _dd=00%%G - set _hour=00%%H - set _minute=00%%I -) -:s_done -:: Pad digits with leading zeros -set _mm=%_mm:~-2% -set _dd=%_dd:~-2% -set _hour=%_hour:~-2% -set _minute=%_minute:~-2% -set iso_date=%_yyyy%-%_mm%-%_dd% - -:CreateDirs -if defined _backups mkdir "%client_dir%\Backups">nul 2>&1 -if defined _info mkdir "%client_dir%\Info">nul 2>&1 -if defined _office mkdir "%client_dir%\Office">nul 2>&1 -if defined _quarantine mkdir "%client_dir%\Quarantine">nul 2>&1 -if defined _quickbooks mkdir "%client_dir%\QuickBooks">nul 2>&1 -if defined _transfer mkdir "%client_dir%\Transfer_%iso_date%">nul 2>&1 -goto Done - -:Abort -color 4e -echo Aborted. -echo. -echo Press any key to exit... -pause>nul -color -rem Set errorlevel to 1 by calling color incorrectly -color 00 -goto Exit - -:Done -goto Exit - -:Exit +:: Wizard Kit: Create client_dir folder(s) + +@echo off +if defined DEBUG (@echo on) + +:SafetyCheck +if not defined bin (goto Abort) + +:Init +set "SETTINGS=%bin%\Scripts\settings\main.py" +for /f "tokens=* usebackq" %%f in (`findstr KIT_NAME_SHORT %SETTINGS%`) do ( + set "_v=%%f" + set "_v=!_v:*'=!" + set "KIT_NAME_SHORT=!_v:~0,-1!" +) +set "client_dir=%systemdrive%\%KIT_NAME_SHORT%" +set "log_dir=%client_dir%\Info\%iso_date%" + +:Flags +set _backups= +set _info= +set _office= +set _quarantine= +set _quickbooks= +set _transfer= +for %%f in (%*) do ( + if /i "%%f" == "/DEBUG" (@echo on) + if /i "%%f" == "/Backups" set _backups=True + if /i "%%f" == "/Info" set _info=True + if /i "%%f" == "/Office" set _office=True + if /i "%%f" == "/Quarantine" set _quarantine=True + if /i "%%f" == "/QuickBooks" set _quickbooks=True + if /i "%%f" == "/Transfer" set _transfer=True +) + +:GetDate +:: Credit to SS64.com Code taken from http://ss64.com/nt/syntax-getdate.html +:: Use WMIC to retrieve date and time in ISO 8601 format. +for /f "skip=1 tokens=1-6" %%G in ('WMIC Path Win32_LocalTime Get Day^,Hour^,Minute^,Month^,Second^,Year /Format:table') do ( + if "%%~L"=="" goto s_done + set _yyyy=%%L + set _mm=00%%J + set _dd=00%%G + set _hour=00%%H + set _minute=00%%I +) +:s_done +:: Pad digits with leading zeros +set _mm=%_mm:~-2% +set _dd=%_dd:~-2% +set _hour=%_hour:~-2% +set _minute=%_minute:~-2% +set iso_date=%_yyyy%-%_mm%-%_dd% + +:CreateDirs +if defined _backups mkdir "%client_dir%\Backups">nul 2>&1 +if defined _info mkdir "%client_dir%\Info">nul 2>&1 +if defined _office mkdir "%client_dir%\Office">nul 2>&1 +if defined _quarantine mkdir "%client_dir%\Quarantine">nul 2>&1 +if defined _quickbooks mkdir "%client_dir%\QuickBooks">nul 2>&1 +if defined _transfer mkdir "%client_dir%\Transfer_%iso_date%">nul 2>&1 +goto Done + +:Abort +color 4e +echo Aborted. +echo. +echo Press any key to exit... +pause>nul +color +rem Set errorlevel to 1 by calling color incorrectly +color 00 +goto Exit + +:Done +goto Exit + +:Exit diff --git a/.bin/Scripts/install_sw_bundle.py b/.bin/Scripts/install_sw_bundle.py index d75a7ed6..a25f20a3 100644 --- a/.bin/Scripts/install_sw_bundle.py +++ b/.bin/Scripts/install_sw_bundle.py @@ -1,59 +1,59 @@ -# Wizard Kit: Install the standard SW bundle based on the OS version - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.setup import * -init_global_vars() -os.system('title {}: SW Bundle Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\Install SW Bundle.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: SW Bundle Tool\n'.format(KIT_NAME_FULL)) - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }, - 'Warning': { - 'GenericRepair': 'Repaired', - 'UnsupportedOSError': 'Unsupported OS', - }} - answer_extensions = ask('Install Extensions?') - answer_adobe_reader = ask('Install Adobe Reader?') - answer_vcr = ask('Install Visual C++ Runtimes?') - answer_ninite = ask('Install Ninite Bundle?') - if answer_ninite and global_vars['OS']['Version'] in ['7']: - # Vista is dead, not going to check for it - answer_mse = ask('Install MSE?') - else: - answer_mse = False - - if answer_extensions: - print_info('Installing Extensions') - try_and_print(message='Classic Shell skin...', - function=install_classicstart_skin, - other_results=other_results) - try_and_print(message='Google Chrome extensions...', - function=install_chrome_extensions) - try_and_print(message='Mozilla Firefox extensions...', - function=install_firefox_extensions) - print_info('Installing Programs') - if answer_adobe_reader: - install_adobe_reader() - if answer_vcr: - install_vcredists() - if answer_ninite: - try_and_print(message='Ninite bundle...', - function=install_ninite_bundle, cs='Started', mse=answer_mse) - print_standard('\nDone.') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Install the standard SW bundle based on the OS version + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.setup import * +init_global_vars() +os.system('title {}: SW Bundle Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\Install SW Bundle.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: SW Bundle Tool\n'.format(KIT_NAME_FULL)) + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }, + 'Warning': { + 'GenericRepair': 'Repaired', + 'UnsupportedOSError': 'Unsupported OS', + }} + answer_extensions = ask('Install Extensions?') + answer_adobe_reader = ask('Install Adobe Reader?') + answer_vcr = ask('Install Visual C++ Runtimes?') + answer_ninite = ask('Install Ninite Bundle?') + if answer_ninite and global_vars['OS']['Version'] in ['7']: + # Vista is dead, not going to check for it + answer_mse = ask('Install MSE?') + else: + answer_mse = False + + if answer_extensions: + print_info('Installing Extensions') + try_and_print(message='Classic Shell skin...', + function=install_classicstart_skin, + other_results=other_results) + try_and_print(message='Google Chrome extensions...', + function=install_chrome_extensions) + try_and_print(message='Mozilla Firefox extensions...', + function=install_firefox_extensions) + print_info('Installing Programs') + if answer_adobe_reader: + install_adobe_reader() + if answer_vcr: + install_vcredists() + if answer_ninite: + try_and_print(message='Ninite bundle...', + function=install_ninite_bundle, cs='Started', mse=answer_mse) + print_standard('\nDone.') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/install_vcredists.py b/.bin/Scripts/install_vcredists.py index 307c5708..e5a14cb0 100644 --- a/.bin/Scripts/install_vcredists.py +++ b/.bin/Scripts/install_vcredists.py @@ -1,34 +1,34 @@ -# Wizard Kit: Install Visual C++ Runtimes - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.setup import * -init_global_vars() -os.system('title {}: Install Visual C++ Runtimes'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\Install Visual C++ Runtimes.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: Install Visual C++ Runtimes\n'.format(KIT_NAME_FULL)) - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }} - - if ask('Install Visual C++ Runtimes?'): - install_vcredists() - else: - abort() - - print_standard('\nDone.') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Install Visual C++ Runtimes + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.setup import * +init_global_vars() +os.system('title {}: Install Visual C++ Runtimes'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\Install Visual C++ Runtimes.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: Install Visual C++ Runtimes\n'.format(KIT_NAME_FULL)) + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }} + + if ask('Install Visual C++ Runtimes?'): + install_vcredists() + else: + abort() + + print_standard('\nDone.') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/safemode_enter.py b/.bin/Scripts/safemode_enter.py index 8421f5d2..f0414375 100644 --- a/.bin/Scripts/safemode_enter.py +++ b/.bin/Scripts/safemode_enter.py @@ -1,44 +1,44 @@ -# Wizard Kit: Enter SafeMode by editing the BCD - -import os -import sys - -# STATIC VARIABLES -REG_MSISERVER = r'HKLM\SYSTEM\CurrentControlSet\Control\SafeBoot\Network\MSIServer' - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.common import * -init_global_vars() -os.system('title {}: SafeMode Tool'.format(KIT_NAME_FULL)) - -if __name__ == '__main__': - try: - os.system('cls') - print_info('{}: SafeMode Tool\n'.format(KIT_NAME_FULL)) - if not ask('Enable booting to SafeMode (with Networking)?'): - abort() - - # Edit BCD to set safeboot as default - cmd = ['bcdedit', '/set', '{default}', 'safeboot', 'network'] - run_program(cmd, check=False) - - # Enable MSI access under safemode - cmd = ['reg', 'add', REG_MSISERVER, '/f'] - run_program(cmd, check=False) - cmd = ['reg', 'add', REG_MSISERVER, '/ve', - '/t', 'REG_SZ', '/d', 'Service', '/f'] - run_program(cmd, check=False) - - ## Done ## - pause('Press Enter to reboot...') - cmd = ['shutdown', '-r', '-t', '3'] - run_program(cmd, check=False) - - # Done - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Enter SafeMode by editing the BCD + +import os +import sys + +# STATIC VARIABLES +REG_MSISERVER = r'HKLM\SYSTEM\CurrentControlSet\Control\SafeBoot\Network\MSIServer' + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.common import * +init_global_vars() +os.system('title {}: SafeMode Tool'.format(KIT_NAME_FULL)) + +if __name__ == '__main__': + try: + os.system('cls') + print_info('{}: SafeMode Tool\n'.format(KIT_NAME_FULL)) + if not ask('Enable booting to SafeMode (with Networking)?'): + abort() + + # Edit BCD to set safeboot as default + cmd = ['bcdedit', '/set', '{default}', 'safeboot', 'network'] + run_program(cmd, check=False) + + # Enable MSI access under safemode + cmd = ['reg', 'add', REG_MSISERVER, '/f'] + run_program(cmd, check=False) + cmd = ['reg', 'add', REG_MSISERVER, '/ve', + '/t', 'REG_SZ', '/d', 'Service', '/f'] + run_program(cmd, check=False) + + ## Done ## + pause('Press Enter to reboot...') + cmd = ['shutdown', '-r', '-t', '3'] + run_program(cmd, check=False) + + # Done + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/safemode_exit.py b/.bin/Scripts/safemode_exit.py index 00a101fe..a1328430 100644 --- a/.bin/Scripts/safemode_exit.py +++ b/.bin/Scripts/safemode_exit.py @@ -1,42 +1,42 @@ -# Wizard Kit: Exit SafeMode by editing the BCD - -import os -import sys - -# STATIC VARIABLES -REG_MSISERVER = r'HKLM\SYSTEM\CurrentControlSet\Control\SafeBoot\Network\MSIServer' - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.common import * -init_global_vars() -os.system('title {}: SafeMode Tool'.format(KIT_NAME_FULL)) - -if __name__ == '__main__': - try: - os.system('cls') - print_info('{}: SafeMode Tool\n'.format(KIT_NAME_FULL)) - if not ask('Disable booting to SafeMode?'): - abort() - - # Edit BCD to remove safeboot value - for boot in ['{current}', '{default}']: - cmd = ['bcdedit', '/deletevalue', boot, 'safeboot'] - run_program(cmd, check=False) - - # Disable MSI access under safemode - cmd = ['reg', 'delete', REG_MSISERVER, '/f'] - run_program(cmd, check=False) - - ## Done ## - pause('Press Enter to reboot...') - cmd = ['shutdown', '-r', '-t', '3'] - run_program(cmd, check=False) - - # Done - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Exit SafeMode by editing the BCD + +import os +import sys + +# STATIC VARIABLES +REG_MSISERVER = r'HKLM\SYSTEM\CurrentControlSet\Control\SafeBoot\Network\MSIServer' + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.common import * +init_global_vars() +os.system('title {}: SafeMode Tool'.format(KIT_NAME_FULL)) + +if __name__ == '__main__': + try: + os.system('cls') + print_info('{}: SafeMode Tool\n'.format(KIT_NAME_FULL)) + if not ask('Disable booting to SafeMode?'): + abort() + + # Edit BCD to remove safeboot value + for boot in ['{current}', '{default}']: + cmd = ['bcdedit', '/deletevalue', boot, 'safeboot'] + run_program(cmd, check=False) + + # Disable MSI access under safemode + cmd = ['reg', 'delete', REG_MSISERVER, '/f'] + run_program(cmd, check=False) + + ## Done ## + pause('Press Enter to reboot...') + cmd = ['shutdown', '-r', '-t', '3'] + run_program(cmd, check=False) + + # Done + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/settings/launchers.py b/.bin/Scripts/settings/launchers.py index 2ec4e0ca..3ba0a39f 100644 --- a/.bin/Scripts/settings/launchers.py +++ b/.bin/Scripts/settings/launchers.py @@ -1,586 +1,586 @@ -# Wizard Kit: Settings - Launchers - -LAUNCHERS = { - r'(Root)': { - 'Activate Windows': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'activate.py', - 'L_ELEV': 'True', - }, - 'Enter SafeMode': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'safemode_enter.py', - 'L_ELEV': 'True', - }, - 'Exit SafeMode': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'safemode_exit.py', - 'L_ELEV': 'True', - }, - 'System Checklist': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'system_checklist.py', - 'L_ELEV': 'True', - }, - 'System Diagnostics': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'system_diagnostics.py', - 'L_ELEV': 'True', - }, - 'User Checklist': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'user_checklist.py', - }, - }, - r'Data Recovery': { - 'PhotoRec (CLI)': { - 'L_TYPE': 'Executable', - 'L_PATH': 'TestDisk', - 'L_ITEM': 'photorec_win.exe', - 'L_ELEV': 'True', - 'L__CLI': 'True', - }, - 'PhotoRec': { - 'L_TYPE': 'Executable', - 'L_PATH': 'TestDisk', - 'L_ITEM': 'qphotorec_win.exe', - 'L_ELEV': 'True', - }, - 'TestDisk': { - 'L_TYPE': 'Executable', - 'L_PATH': 'TestDisk', - 'L_ITEM': 'testdisk_win.exe', - 'L_ELEV': 'True', - 'L__CLI': 'True', - }, - }, - r'Data Transfers': { - 'FastCopy (as ADMIN)': { - 'L_TYPE': 'Executable', - 'L_PATH': 'FastCopy', - 'L_ITEM': 'FastCopy.exe', - 'L_ARGS': ( - r' /logfile=%log_dir%\FastCopy.log' - r' /cmd=noexist_only' - r' /utf8' - r' /skip_empty_dir' - r' /linkdest' - r' /exclude=' - r'$RECYCLE.BIN;' - r'$Recycle.Bin;' - r'.AppleDB;' - r'.AppleDesktop;' - r'.AppleDouble;' - r'.com.apple.timemachine.supported;' - r'.dbfseventsd;' - r'.DocumentRevisions-V100*;' - r'.DS_Store;' - r'.fseventsd;' - r'.PKInstallSandboxManager;' - r'.Spotlight*;' - r'.SymAV*;' - r'.symSchedScanLockxz;' - r'.TemporaryItems;' - r'.Trash*;' - r'.vol;' - r'.VolumeIcon.icns;' - r'desktop.ini;' - r'Desktop?DB;' - r'Desktop?DF;' - r'hiberfil.sys;' - r'lost+found;' - r'Network?Trash?Folder;' - r'pagefile.sys;' - r'Recycled;' - r'RECYCLER;' - r'System?Volume?Information;' - r'Temporary?Items;' - r'Thumbs.db' - r' /to=%client_dir%\Transfer_%iso_date%\ ' - ), - 'L_ELEV': 'True', - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Info /Transfer', - ], - }, - 'FastCopy': { - 'L_TYPE': 'Executable', - 'L_PATH': 'FastCopy', - 'L_ITEM': 'FastCopy.exe', - 'L_ARGS': ( - r' /logfile=%log_dir%\FastCopy.log' - r' /cmd=noexist_only' - r' /utf8' - r' /skip_empty_dir' - r' /linkdest' - r' /exclude=' - r'$RECYCLE.BIN;' - r'$Recycle.Bin;' - r'.AppleDB;' - r'.AppleDesktop;' - r'.AppleDouble;' - r'.com.apple.timemachine.supported;' - r'.dbfseventsd;' - r'.DocumentRevisions-V100*;' - r'.DS_Store;' - r'.fseventsd;' - r'.PKInstallSandboxManager;' - r'.Spotlight*;' - r'.SymAV*;' - r'.symSchedScanLockxz;' - r'.TemporaryItems;' - r'.Trash*;' - r'.vol;' - r'.VolumeIcon.icns;' - r'desktop.ini;' - r'Desktop?DB;' - r'Desktop?DF;' - r'hiberfil.sys;' - r'lost+found;' - r'Network?Trash?Folder;' - r'pagefile.sys;' - r'Recycled;' - r'RECYCLER;' - r'System?Volume?Information;' - r'Temporary?Items;' - r'Thumbs.db' - r' /to=%client_dir%\Transfer_%iso_date%\ ' - ), - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Info /Transfer', - ], - }, - 'KVRT': { - 'L_TYPE': 'Executable', - 'L_PATH': 'KVRT', - 'L_ITEM': 'KVRT.exe', - 'L_ARGS': ( - r' -accepteula' - r' -d %q_dir%' - r' -processlevel 3' - r' -dontcryptsupportinfo' - r' -fixednames' - ), - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Quarantine', - r'set "q_dir=%client_dir%\Quarantine\KVRT"', - r'mkdir "%q_dir%">nul 2>&1', - ], - }, - 'Transferred Keys': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'transferred_keys.py', - 'L_ELEV': 'True', - }, - 'User Data Transfer': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'user_data_transfer.py', - 'L_ELEV': 'True', - }, - 'XYplorer (as ADMIN)': { - 'L_TYPE': 'Executable', - 'L_PATH': 'XYplorerFree', - 'L_ITEM': 'XYplorerFree.exe', - 'L_ARGS': r'/exp /win=max %userprofile%', - 'L_ELEV': 'True', - }, - 'XYplorer': { - 'L_TYPE': 'Executable', - 'L_PATH': 'XYplorerFree', - 'L_ITEM': 'XYplorerFree.exe', - 'L_ARGS': r'/exp /win=max %userprofile%', - }, - }, - r'Diagnostics': { - 'HWiNFO': { - 'L_TYPE': 'Executable', - 'L_PATH': 'HWiNFO', - 'L_ITEM': 'HWiNFO.exe', - 'Extra Code': [ - r'for %%a in (32 64) do (', - r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r')', - ], - }, - 'ProduKey': { - 'L_TYPE': 'Executable', - 'L_PATH': 'ProduKey', - 'L_ITEM': 'ProduKey.exe', - 'L_ELEV': 'True', - 'Extra Code': [ - r'if exist "%bin%\ProduKey" (', - r' del "%bin%\ProduKey\ProduKey.cfg" 2>nul', - r' del "%bin%\ProduKey\ProduKey64.cfg" 2>nul', - r')', - ], - }, - }, - r'Diagnostics\Extras': { - 'AIDA64': { - 'L_TYPE': 'Executable', - 'L_PATH': 'AIDA64', - 'L_ITEM': 'aida64.exe', - }, - 'Autoruns (with VirusTotal Scan)': { - 'L_TYPE': 'Executable', - 'L_PATH': 'Autoruns', - 'L_ITEM': 'Autoruns.exe', - 'L_ARGS': '-e', - 'Extra Code': [ - r'reg add HKCU\Software\Sysinternals\AutoRuns /v checkvirustotal /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v EulaAccepted /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownomicrosoft /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownowindows /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v showonlyvirustotal /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v submitvirustotal /t REG_DWORD /d 0 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v verifysignatures /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns\SigCheck /v EulaAccepted /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns\Streams /v EulaAccepted /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns\VirusTotal /v VirusTotalTermsAccepted /t REG_DWORD /d 1 /f >nul', - ], - }, - 'BleachBit': { - 'L_TYPE': 'Executable', - 'L_PATH': 'BleachBit', - 'L_ITEM': 'bleachbit.exe', - }, - 'BlueScreenView': { - 'L_TYPE': 'Executable', - 'L_PATH': 'BlueScreenView', - 'L_ITEM': 'BlueScreenView.exe', - }, - 'ERUNT': { - 'L_TYPE': 'Executable', - 'L_PATH': 'erunt', - 'L_ITEM': 'ERUNT.EXE', - 'L_ARGS': '%log_dir%\Registry sysreg curuser otherusers', - 'L_ELEV': 'True', - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Info', - ], - }, - 'HitmanPro': { - 'L_TYPE': 'Executable', - 'L_PATH': 'HitmanPro', - 'L_ITEM': 'HitmanPro.exe', - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Info', - ], - }, - 'HWiNFO (Sensors)': { - 'L_TYPE': 'Executable', - 'L_PATH': 'HWiNFO', - 'L_ITEM': 'HWiNFO.exe', - 'Extra Code': [ - r'for %%a in (32 64) do (', - r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SensorsOnly=1)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r')', - ], - }, - }, - r'Drivers': { - 'Intel RST (Current Release)': { - 'L_TYPE': 'Executable', - 'L_PATH': '_Drivers\Intel RST', - 'L_ITEM': 'SetupRST_15.8.exe', - 'L_7ZIP': 'SetupRST_15.8.exe', - }, - 'Intel RST (Previous Releases)': { - 'L_TYPE': 'Folder', - 'L_PATH': '_Drivers\Intel RST', - 'L_ITEM': '.', - 'L_NCMD': 'True', - }, - 'Intel SSD Toolbox': { - 'L_TYPE': 'Executable', - 'L_PATH': r'_Drivers\Intel SSD Toolbox', - 'L_ITEM': 'Intel SSD Toolbox.exe', - }, - 'Samsing Magician': { - 'L_TYPE': 'Executable', - 'L_PATH': r'_Drivers\Samsung Magician', - 'L_ITEM': 'Samsung Magician.exe', - }, - 'Snappy Driver Installer Origin': { - 'L_TYPE': 'Executable', - 'L_PATH': '_Drivers\SDIO', - 'L_ITEM': 'SDIO.exe', - }, - }, - r'Drivers\Extras': { - 'Acer': { - 'L_TYPE': 'Executable', - 'L_PATH': 'HWiNFO', - 'L_ITEM': 'HWiNFO.exe', - 'Extra Code': [ - r'for %%a in (32 64) do (', - r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r')', - r'start "" "http://us.acer.com/ac/en/US/content/drivers"', - ], - }, - 'Lenovo': { - 'L_TYPE': 'Executable', - 'L_PATH': 'HWiNFO', - 'L_ITEM': 'HWiNFO.exe', - 'Extra Code': [ - r'for %%a in (32 64) do (', - r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r')', - r'start "" "http://support.lenovo.com/us/en/products?tabName=Downloads"', - ], - }, - 'Toshiba': { - 'L_TYPE': 'Executable', - 'L_PATH': 'HWiNFO', - 'L_ITEM': 'HWiNFO.exe', - 'Extra Code': [ - r'for %%a in (32 64) do (', - r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', - r')', - r'start "" "http://support.toshiba.com/drivers"', - ], - }, - }, - r'Installers': { - 'SW Bundle': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'install_sw_bundle.py', - 'L_ELEV': 'True', - }, - }, - r'Installers\Extras\Office\2013': { - 'Home and Business 2013 (x32)': { - 'L_TYPE': 'Office', - 'L_PATH': '2013', - 'L_ITEM': 'hb_32.xml', - 'L_NCMD': 'True', - }, - 'Home and Business 2013 (x64)': { - 'L_TYPE': 'Office', - 'L_PATH': '2013', - 'L_ITEM': 'hb_64.xml', - 'L_NCMD': 'True', - }, - 'Home and Student 2013 (x32)': { - 'L_TYPE': 'Office', - 'L_PATH': '2013', - 'L_ITEM': 'hs_32.xml', - 'L_NCMD': 'True', - }, - 'Home and Student 2013 (x64)': { - 'L_TYPE': 'Office', - 'L_PATH': '2013', - 'L_ITEM': 'hs_64.xml', - 'L_NCMD': 'True', - }, - }, - r'Installers\Extras\Office\2016': { - 'Home and Business 2016 (x32)': { - 'L_TYPE': 'Office', - 'L_PATH': '2016', - 'L_ITEM': 'hb_32.xml', - 'L_NCMD': 'True', - }, - 'Home and Business 2016 (x64)': { - 'L_TYPE': 'Office', - 'L_PATH': '2016', - 'L_ITEM': 'hb_64.xml', - 'L_NCMD': 'True', - }, - 'Home and Student 2016 (x32)': { - 'L_TYPE': 'Office', - 'L_PATH': '2016', - 'L_ITEM': 'hs_32.xml', - 'L_NCMD': 'True', - }, - 'Home and Student 2016 (x64)': { - 'L_TYPE': 'Office', - 'L_PATH': '2016', - 'L_ITEM': 'hs_64.xml', - 'L_NCMD': 'True', - }, - 'Office 365 2016 (x32)': { - 'L_TYPE': 'Office', - 'L_PATH': '2016', - 'L_ITEM': '365_32.xml', - 'L_NCMD': 'True', - }, - 'Office 365 2016 (x64)': { - 'L_TYPE': 'Office', - 'L_PATH': '2016', - 'L_ITEM': '365_64.xml', - 'L_NCMD': 'True', - }, - }, - r'Installers\Extras\Runtimes': { - 'Visual C++ Runtimes': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'install_vcredists.py', - 'L_ELEV': 'True', - }, - }, - r'Misc': { - 'ConEmu (as ADMIN)': { - 'L_TYPE': 'Executable', - 'L_PATH': 'ConEmu', - 'L_ITEM': 'ConEmu.exe', - 'L_ELEV': 'True', - }, - 'ConEmu': { - 'L_TYPE': 'Executable', - 'L_PATH': 'ConEmu', - 'L_ITEM': 'ConEmu.exe', - }, - 'Everything': { - 'L_TYPE': 'Executable', - 'L_PATH': 'Everything', - 'L_ITEM': 'Everything.exe', - 'L_ARGS': '-nodb', - 'L_ELEV': 'True', - }, - 'Notepad++': { - 'L_TYPE': 'Executable', - 'L_PATH': 'notepadplusplus', - 'L_ITEM': 'notepadplusplus.exe', - }, - 'PuTTY': { - 'L_TYPE': 'Executable', - 'L_PATH': 'PuTTY', - 'L_ITEM': 'PUTTY.EXE', - }, - 'TreeSizeFree': { - 'L_TYPE': 'Executable', - 'L_PATH': 'TreeSizeFree', - 'L_ITEM': 'TreeSizeFree.exe', - 'L_ELEV': 'True', - }, - 'Update Kit': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'update_kit.py', - }, - 'XMPlay': { - 'L_TYPE': 'Executable', - 'L_PATH': 'XMPlay', - 'L_ITEM': 'xmplay.exe', - 'L_ARGS': '"%bin%\XMPlay\music.7z"', - }, - }, - r'Repairs': { - 'AdwCleaner': { - 'L_TYPE': 'Executable', - 'L_PATH': 'AdwCleaner', - 'L_ITEM': 'AdwCleaner.exe', - }, - 'Autoruns': { - 'L_TYPE': 'Executable', - 'L_PATH': 'Autoruns', - 'L_ITEM': 'Autoruns.exe', - 'L_ARGS': '-e', - 'Extra Code': [ - r'reg add HKCU\Software\Sysinternals\AutoRuns /v checkvirustotal /t REG_DWORD /d 0 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v EulaAccepted /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownomicrosoft /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownowindows /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v showonlyvirustotal /t REG_DWORD /d 0 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v submitvirustotal /t REG_DWORD /d 0 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns /v verifysignatures /t REG_DWORD /d 0 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns\SigCheck /v EulaAccepted /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns\Streams /v EulaAccepted /t REG_DWORD /d 1 /f >nul', - r'reg add HKCU\Software\Sysinternals\AutoRuns\VirusTotal /v VirusTotalTermsAccepted /t REG_DWORD /d 1 /f >nul', - ], - }, - 'CHKDSK': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'check_disk.py', - 'L_ELEV': 'True', - }, - 'DISM': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'dism.py', - 'L_ELEV': 'True', - }, - 'KVRT': { - 'L_TYPE': 'Executable', - 'L_PATH': 'KVRT', - 'L_ITEM': 'KVRT.exe', - 'L_ARGS': ( - r' -accepteula' - r' -d %q_dir%' - r' -processlevel 3' - r' -dontcryptsupportinfo' - r' -fixednames' - ), - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Quarantine', - r'set "q_dir=%client_dir%\Quarantine\KVRT"', - r'mkdir "%q_dir%">nul 2>&1', - ], - }, - 'RKill': { - 'L_TYPE': 'Executable', - 'L_PATH': 'RKill', - 'L_ITEM': 'RKill.exe', - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Info', - ], - }, - 'SFC Scan': { - 'L_TYPE': 'PyScript', - 'L_PATH': 'Scripts', - 'L_ITEM': 'sfc_scan.py', - 'L_ELEV': 'True', - }, - 'TDSSKiller': { - 'L_TYPE': 'Executable', - 'L_PATH': 'TDSSKiller', - 'L_ITEM': 'TDSSKiller.exe', - 'L_ARGS': ( - r' -l %log_dir%\TDSSKiller.log' - r' -qpath %q_dir%' - r' -accepteula' - r' -accepteulaksn' - r' -dcexact' - r' -tdlfs' - ), - 'Extra Code': [ - r'call "%bin%\Scripts\init_client_dir.cmd" /Quarantine', - r'set "q_dir=%client_dir%\Quarantine\TDSSKiller"', - r'mkdir "%q_dir%">nul 2>&1', - ], - }, - }, - r'Uninstallers': { - 'IObit Uninstaller': { - 'L_TYPE': 'Executable', - 'L_PATH': 'IObitUninstallerPortable', - 'L_ITEM': 'IObitUninstallerPortable.exe', - }, - }, - } - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Settings - Launchers + +LAUNCHERS = { + r'(Root)': { + 'Activate Windows': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'activate.py', + 'L_ELEV': 'True', + }, + 'Enter SafeMode': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'safemode_enter.py', + 'L_ELEV': 'True', + }, + 'Exit SafeMode': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'safemode_exit.py', + 'L_ELEV': 'True', + }, + 'System Checklist': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'system_checklist.py', + 'L_ELEV': 'True', + }, + 'System Diagnostics': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'system_diagnostics.py', + 'L_ELEV': 'True', + }, + 'User Checklist': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'user_checklist.py', + }, + }, + r'Data Recovery': { + 'PhotoRec (CLI)': { + 'L_TYPE': 'Executable', + 'L_PATH': 'TestDisk', + 'L_ITEM': 'photorec_win.exe', + 'L_ELEV': 'True', + 'L__CLI': 'True', + }, + 'PhotoRec': { + 'L_TYPE': 'Executable', + 'L_PATH': 'TestDisk', + 'L_ITEM': 'qphotorec_win.exe', + 'L_ELEV': 'True', + }, + 'TestDisk': { + 'L_TYPE': 'Executable', + 'L_PATH': 'TestDisk', + 'L_ITEM': 'testdisk_win.exe', + 'L_ELEV': 'True', + 'L__CLI': 'True', + }, + }, + r'Data Transfers': { + 'FastCopy (as ADMIN)': { + 'L_TYPE': 'Executable', + 'L_PATH': 'FastCopy', + 'L_ITEM': 'FastCopy.exe', + 'L_ARGS': ( + r' /logfile=%log_dir%\FastCopy.log' + r' /cmd=noexist_only' + r' /utf8' + r' /skip_empty_dir' + r' /linkdest' + r' /exclude=' + r'$RECYCLE.BIN;' + r'$Recycle.Bin;' + r'.AppleDB;' + r'.AppleDesktop;' + r'.AppleDouble;' + r'.com.apple.timemachine.supported;' + r'.dbfseventsd;' + r'.DocumentRevisions-V100*;' + r'.DS_Store;' + r'.fseventsd;' + r'.PKInstallSandboxManager;' + r'.Spotlight*;' + r'.SymAV*;' + r'.symSchedScanLockxz;' + r'.TemporaryItems;' + r'.Trash*;' + r'.vol;' + r'.VolumeIcon.icns;' + r'desktop.ini;' + r'Desktop?DB;' + r'Desktop?DF;' + r'hiberfil.sys;' + r'lost+found;' + r'Network?Trash?Folder;' + r'pagefile.sys;' + r'Recycled;' + r'RECYCLER;' + r'System?Volume?Information;' + r'Temporary?Items;' + r'Thumbs.db' + r' /to=%client_dir%\Transfer_%iso_date%\ ' + ), + 'L_ELEV': 'True', + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Info /Transfer', + ], + }, + 'FastCopy': { + 'L_TYPE': 'Executable', + 'L_PATH': 'FastCopy', + 'L_ITEM': 'FastCopy.exe', + 'L_ARGS': ( + r' /logfile=%log_dir%\FastCopy.log' + r' /cmd=noexist_only' + r' /utf8' + r' /skip_empty_dir' + r' /linkdest' + r' /exclude=' + r'$RECYCLE.BIN;' + r'$Recycle.Bin;' + r'.AppleDB;' + r'.AppleDesktop;' + r'.AppleDouble;' + r'.com.apple.timemachine.supported;' + r'.dbfseventsd;' + r'.DocumentRevisions-V100*;' + r'.DS_Store;' + r'.fseventsd;' + r'.PKInstallSandboxManager;' + r'.Spotlight*;' + r'.SymAV*;' + r'.symSchedScanLockxz;' + r'.TemporaryItems;' + r'.Trash*;' + r'.vol;' + r'.VolumeIcon.icns;' + r'desktop.ini;' + r'Desktop?DB;' + r'Desktop?DF;' + r'hiberfil.sys;' + r'lost+found;' + r'Network?Trash?Folder;' + r'pagefile.sys;' + r'Recycled;' + r'RECYCLER;' + r'System?Volume?Information;' + r'Temporary?Items;' + r'Thumbs.db' + r' /to=%client_dir%\Transfer_%iso_date%\ ' + ), + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Info /Transfer', + ], + }, + 'KVRT': { + 'L_TYPE': 'Executable', + 'L_PATH': 'KVRT', + 'L_ITEM': 'KVRT.exe', + 'L_ARGS': ( + r' -accepteula' + r' -d %q_dir%' + r' -processlevel 3' + r' -dontcryptsupportinfo' + r' -fixednames' + ), + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Quarantine', + r'set "q_dir=%client_dir%\Quarantine\KVRT"', + r'mkdir "%q_dir%">nul 2>&1', + ], + }, + 'Transferred Keys': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'transferred_keys.py', + 'L_ELEV': 'True', + }, + 'User Data Transfer': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'user_data_transfer.py', + 'L_ELEV': 'True', + }, + 'XYplorer (as ADMIN)': { + 'L_TYPE': 'Executable', + 'L_PATH': 'XYplorerFree', + 'L_ITEM': 'XYplorerFree.exe', + 'L_ARGS': r'/exp /win=max %userprofile%', + 'L_ELEV': 'True', + }, + 'XYplorer': { + 'L_TYPE': 'Executable', + 'L_PATH': 'XYplorerFree', + 'L_ITEM': 'XYplorerFree.exe', + 'L_ARGS': r'/exp /win=max %userprofile%', + }, + }, + r'Diagnostics': { + 'HWiNFO': { + 'L_TYPE': 'Executable', + 'L_PATH': 'HWiNFO', + 'L_ITEM': 'HWiNFO.exe', + 'Extra Code': [ + r'for %%a in (32 64) do (', + r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r')', + ], + }, + 'ProduKey': { + 'L_TYPE': 'Executable', + 'L_PATH': 'ProduKey', + 'L_ITEM': 'ProduKey.exe', + 'L_ELEV': 'True', + 'Extra Code': [ + r'if exist "%bin%\ProduKey" (', + r' del "%bin%\ProduKey\ProduKey.cfg" 2>nul', + r' del "%bin%\ProduKey\ProduKey64.cfg" 2>nul', + r')', + ], + }, + }, + r'Diagnostics\Extras': { + 'AIDA64': { + 'L_TYPE': 'Executable', + 'L_PATH': 'AIDA64', + 'L_ITEM': 'aida64.exe', + }, + 'Autoruns (with VirusTotal Scan)': { + 'L_TYPE': 'Executable', + 'L_PATH': 'Autoruns', + 'L_ITEM': 'Autoruns.exe', + 'L_ARGS': '-e', + 'Extra Code': [ + r'reg add HKCU\Software\Sysinternals\AutoRuns /v checkvirustotal /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v EulaAccepted /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownomicrosoft /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownowindows /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v showonlyvirustotal /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v submitvirustotal /t REG_DWORD /d 0 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v verifysignatures /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns\SigCheck /v EulaAccepted /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns\Streams /v EulaAccepted /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns\VirusTotal /v VirusTotalTermsAccepted /t REG_DWORD /d 1 /f >nul', + ], + }, + 'BleachBit': { + 'L_TYPE': 'Executable', + 'L_PATH': 'BleachBit', + 'L_ITEM': 'bleachbit.exe', + }, + 'BlueScreenView': { + 'L_TYPE': 'Executable', + 'L_PATH': 'BlueScreenView', + 'L_ITEM': 'BlueScreenView.exe', + }, + 'ERUNT': { + 'L_TYPE': 'Executable', + 'L_PATH': 'erunt', + 'L_ITEM': 'ERUNT.EXE', + 'L_ARGS': '%log_dir%\Registry sysreg curuser otherusers', + 'L_ELEV': 'True', + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Info', + ], + }, + 'HitmanPro': { + 'L_TYPE': 'Executable', + 'L_PATH': 'HitmanPro', + 'L_ITEM': 'HitmanPro.exe', + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Info', + ], + }, + 'HWiNFO (Sensors)': { + 'L_TYPE': 'Executable', + 'L_PATH': 'HWiNFO', + 'L_ITEM': 'HWiNFO.exe', + 'Extra Code': [ + r'for %%a in (32 64) do (', + r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SensorsOnly=1)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r')', + ], + }, + }, + r'Drivers': { + 'Intel RST (Current Release)': { + 'L_TYPE': 'Executable', + 'L_PATH': '_Drivers\Intel RST', + 'L_ITEM': 'SetupRST_15.8.exe', + 'L_7ZIP': 'SetupRST_15.8.exe', + }, + 'Intel RST (Previous Releases)': { + 'L_TYPE': 'Folder', + 'L_PATH': '_Drivers\Intel RST', + 'L_ITEM': '.', + 'L_NCMD': 'True', + }, + 'Intel SSD Toolbox': { + 'L_TYPE': 'Executable', + 'L_PATH': r'_Drivers\Intel SSD Toolbox', + 'L_ITEM': 'Intel SSD Toolbox.exe', + }, + 'Samsing Magician': { + 'L_TYPE': 'Executable', + 'L_PATH': r'_Drivers\Samsung Magician', + 'L_ITEM': 'Samsung Magician.exe', + }, + 'Snappy Driver Installer Origin': { + 'L_TYPE': 'Executable', + 'L_PATH': '_Drivers\SDIO', + 'L_ITEM': 'SDIO.exe', + }, + }, + r'Drivers\Extras': { + 'Acer': { + 'L_TYPE': 'Executable', + 'L_PATH': 'HWiNFO', + 'L_ITEM': 'HWiNFO.exe', + 'Extra Code': [ + r'for %%a in (32 64) do (', + r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r')', + r'start "" "http://us.acer.com/ac/en/US/content/drivers"', + ], + }, + 'Lenovo': { + 'L_TYPE': 'Executable', + 'L_PATH': 'HWiNFO', + 'L_ITEM': 'HWiNFO.exe', + 'Extra Code': [ + r'for %%a in (32 64) do (', + r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r')', + r'start "" "http://support.lenovo.com/us/en/products?tabName=Downloads"', + ], + }, + 'Toshiba': { + 'L_TYPE': 'Executable', + 'L_PATH': 'HWiNFO', + 'L_ITEM': 'HWiNFO.exe', + 'Extra Code': [ + r'for %%a in (32 64) do (', + r' copy /y "%bin%\HWiNFO\general.ini" "%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SensorsOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r' (echo SummaryOnly=0)>>"%bin%\HWiNFO\HWiNFO%%a.ini"', + r')', + r'start "" "http://support.toshiba.com/drivers"', + ], + }, + }, + r'Installers': { + 'SW Bundle': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'install_sw_bundle.py', + 'L_ELEV': 'True', + }, + }, + r'Installers\Extras\Office\2013': { + 'Home and Business 2013 (x32)': { + 'L_TYPE': 'Office', + 'L_PATH': '2013', + 'L_ITEM': 'hb_32.xml', + 'L_NCMD': 'True', + }, + 'Home and Business 2013 (x64)': { + 'L_TYPE': 'Office', + 'L_PATH': '2013', + 'L_ITEM': 'hb_64.xml', + 'L_NCMD': 'True', + }, + 'Home and Student 2013 (x32)': { + 'L_TYPE': 'Office', + 'L_PATH': '2013', + 'L_ITEM': 'hs_32.xml', + 'L_NCMD': 'True', + }, + 'Home and Student 2013 (x64)': { + 'L_TYPE': 'Office', + 'L_PATH': '2013', + 'L_ITEM': 'hs_64.xml', + 'L_NCMD': 'True', + }, + }, + r'Installers\Extras\Office\2016': { + 'Home and Business 2016 (x32)': { + 'L_TYPE': 'Office', + 'L_PATH': '2016', + 'L_ITEM': 'hb_32.xml', + 'L_NCMD': 'True', + }, + 'Home and Business 2016 (x64)': { + 'L_TYPE': 'Office', + 'L_PATH': '2016', + 'L_ITEM': 'hb_64.xml', + 'L_NCMD': 'True', + }, + 'Home and Student 2016 (x32)': { + 'L_TYPE': 'Office', + 'L_PATH': '2016', + 'L_ITEM': 'hs_32.xml', + 'L_NCMD': 'True', + }, + 'Home and Student 2016 (x64)': { + 'L_TYPE': 'Office', + 'L_PATH': '2016', + 'L_ITEM': 'hs_64.xml', + 'L_NCMD': 'True', + }, + 'Office 365 2016 (x32)': { + 'L_TYPE': 'Office', + 'L_PATH': '2016', + 'L_ITEM': '365_32.xml', + 'L_NCMD': 'True', + }, + 'Office 365 2016 (x64)': { + 'L_TYPE': 'Office', + 'L_PATH': '2016', + 'L_ITEM': '365_64.xml', + 'L_NCMD': 'True', + }, + }, + r'Installers\Extras\Runtimes': { + 'Visual C++ Runtimes': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'install_vcredists.py', + 'L_ELEV': 'True', + }, + }, + r'Misc': { + 'ConEmu (as ADMIN)': { + 'L_TYPE': 'Executable', + 'L_PATH': 'ConEmu', + 'L_ITEM': 'ConEmu.exe', + 'L_ELEV': 'True', + }, + 'ConEmu': { + 'L_TYPE': 'Executable', + 'L_PATH': 'ConEmu', + 'L_ITEM': 'ConEmu.exe', + }, + 'Everything': { + 'L_TYPE': 'Executable', + 'L_PATH': 'Everything', + 'L_ITEM': 'Everything.exe', + 'L_ARGS': '-nodb', + 'L_ELEV': 'True', + }, + 'Notepad++': { + 'L_TYPE': 'Executable', + 'L_PATH': 'notepadplusplus', + 'L_ITEM': 'notepadplusplus.exe', + }, + 'PuTTY': { + 'L_TYPE': 'Executable', + 'L_PATH': 'PuTTY', + 'L_ITEM': 'PUTTY.EXE', + }, + 'TreeSizeFree': { + 'L_TYPE': 'Executable', + 'L_PATH': 'TreeSizeFree', + 'L_ITEM': 'TreeSizeFree.exe', + 'L_ELEV': 'True', + }, + 'Update Kit': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'update_kit.py', + }, + 'XMPlay': { + 'L_TYPE': 'Executable', + 'L_PATH': 'XMPlay', + 'L_ITEM': 'xmplay.exe', + 'L_ARGS': '"%bin%\XMPlay\music.7z"', + }, + }, + r'Repairs': { + 'AdwCleaner': { + 'L_TYPE': 'Executable', + 'L_PATH': 'AdwCleaner', + 'L_ITEM': 'AdwCleaner.exe', + }, + 'Autoruns': { + 'L_TYPE': 'Executable', + 'L_PATH': 'Autoruns', + 'L_ITEM': 'Autoruns.exe', + 'L_ARGS': '-e', + 'Extra Code': [ + r'reg add HKCU\Software\Sysinternals\AutoRuns /v checkvirustotal /t REG_DWORD /d 0 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v EulaAccepted /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownomicrosoft /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v shownowindows /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v showonlyvirustotal /t REG_DWORD /d 0 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v submitvirustotal /t REG_DWORD /d 0 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns /v verifysignatures /t REG_DWORD /d 0 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns\SigCheck /v EulaAccepted /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns\Streams /v EulaAccepted /t REG_DWORD /d 1 /f >nul', + r'reg add HKCU\Software\Sysinternals\AutoRuns\VirusTotal /v VirusTotalTermsAccepted /t REG_DWORD /d 1 /f >nul', + ], + }, + 'CHKDSK': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'check_disk.py', + 'L_ELEV': 'True', + }, + 'DISM': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'dism.py', + 'L_ELEV': 'True', + }, + 'KVRT': { + 'L_TYPE': 'Executable', + 'L_PATH': 'KVRT', + 'L_ITEM': 'KVRT.exe', + 'L_ARGS': ( + r' -accepteula' + r' -d %q_dir%' + r' -processlevel 3' + r' -dontcryptsupportinfo' + r' -fixednames' + ), + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Quarantine', + r'set "q_dir=%client_dir%\Quarantine\KVRT"', + r'mkdir "%q_dir%">nul 2>&1', + ], + }, + 'RKill': { + 'L_TYPE': 'Executable', + 'L_PATH': 'RKill', + 'L_ITEM': 'RKill.exe', + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Info', + ], + }, + 'SFC Scan': { + 'L_TYPE': 'PyScript', + 'L_PATH': 'Scripts', + 'L_ITEM': 'sfc_scan.py', + 'L_ELEV': 'True', + }, + 'TDSSKiller': { + 'L_TYPE': 'Executable', + 'L_PATH': 'TDSSKiller', + 'L_ITEM': 'TDSSKiller.exe', + 'L_ARGS': ( + r' -l %log_dir%\TDSSKiller.log' + r' -qpath %q_dir%' + r' -accepteula' + r' -accepteulaksn' + r' -dcexact' + r' -tdlfs' + ), + 'Extra Code': [ + r'call "%bin%\Scripts\init_client_dir.cmd" /Quarantine', + r'set "q_dir=%client_dir%\Quarantine\TDSSKiller"', + r'mkdir "%q_dir%">nul 2>&1', + ], + }, + }, + r'Uninstallers': { + 'IObit Uninstaller': { + 'L_TYPE': 'Executable', + 'L_PATH': 'IObitUninstallerPortable', + 'L_ITEM': 'IObitUninstallerPortable.exe', + }, + }, + } + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/settings/main.py b/.bin/Scripts/settings/main.py index e8c828d4..832719f8 100644 --- a/.bin/Scripts/settings/main.py +++ b/.bin/Scripts/settings/main.py @@ -1,68 +1,68 @@ -# Wizard Kit: Settings - Main / Branding - -# Features -ENABLED_UPLOAD_DATA = False - -# STATIC VARIABLES (also used by .cmd files) -## Not using spaces aroung '=' for easier .cmd substrings -ARCHIVE_PASSWORD='Abracadabra' -KIT_NAME_FULL='Wizard Kit' -KIT_NAME_SHORT='WK' -OFFICE_SERVER_IP='10.0.0.10' -QUICKBOOKS_SERVER_IP='10.0.0.10' -SUPPORT_TECH='2Shirt' -TIME_ZONE='Pacific Standard Time' # Always use "Standard Time" (DST is applied correctly) - -# SERVER VARIABLES -## NOTE: Windows can only use one user per server. This means that if -## one server serves multiple shares then you have to use the same -## user/password for all of those shares. -BACKUP_SERVERS = [ - { 'IP': '10.0.0.10', - 'Name': 'ServerOne', - 'Mounted': False, - 'Share': 'Backups', - 'User': 'restore', - 'Pass': 'Abracadabra', - }, - { 'IP': '10.0.0.11', - 'Name': 'ServerTwo', - 'Mounted': False, - 'Share': 'Backups', - 'User': 'restore', - 'Pass': 'Abracadabra', - }, -] -CLIENT_INFO_SERVER = { - 'IP': '10.0.0.10', - 'RegEntry': r'0x10001,0xcc674aebbd889f5fd553564adcf3cab550791eca12542033d52134db893c95aabb6b318a4621d8116f6838d873edfe9db4509e1dfc9177ee7484808a62cbc42b913387f694fd67e81950f85198acf721c5767b54db7b864d69cce65e12c78c87d0fb4fc54996609c9b9274b1de7bae2f95000c9ca8d7e3f9b3f2cdb21cd578adf9ba98d10400a8203bb1a879a4cd2fad99baeb12738b9b4b99fec821f881acb62598a43c059f74af287bc8dceeb4821317aa44e2e0ee66d346927a654c702854a71a2eaed6a53f6be9360c7049974a2597a548361da42ac982ae55f993700a8b1fc9f3b4458314fbd41f239de0a29716cdcefbbb2c8d02b4c2effa4163cfeac9', - 'Share': '/srv/ClientInfo', - 'User': 'upload', -} -OFFICE_SERVER = { - 'IP': OFFICE_SERVER_IP, - 'Name': 'ServerOne', - 'Mounted': False, - 'Share': 'Office', - 'User': 'restore', - 'Pass': 'Abracadabra', -} -QUICKBOOKS_SERVER = { - 'IP': QUICKBOOKS_SERVER_IP, - 'Name': 'ServerOne', - 'Mounted': False, - 'Share': 'QuickBooks', - 'User': 'restore', - 'Pass': 'Abracadabra', -} -WINDOWS_SERVER = { - 'IP': '10.0.0.10', - 'Name': 'ServerOne', - 'Mounted': False, - 'Share': 'Windows', - 'User': 'restore', - 'Pass': 'Abracadabra', -} - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Settings - Main / Branding + +# Features +ENABLED_UPLOAD_DATA = False + +# STATIC VARIABLES (also used by .cmd files) +## Not using spaces aroung '=' for easier .cmd substrings +ARCHIVE_PASSWORD='Abracadabra' +KIT_NAME_FULL='Wizard Kit' +KIT_NAME_SHORT='WK' +OFFICE_SERVER_IP='10.0.0.10' +QUICKBOOKS_SERVER_IP='10.0.0.10' +SUPPORT_TECH='2Shirt' +TIME_ZONE='Pacific Standard Time' # Always use "Standard Time" (DST is applied correctly) + +# SERVER VARIABLES +## NOTE: Windows can only use one user per server. This means that if +## one server serves multiple shares then you have to use the same +## user/password for all of those shares. +BACKUP_SERVERS = [ + { 'IP': '10.0.0.10', + 'Name': 'ServerOne', + 'Mounted': False, + 'Share': 'Backups', + 'User': 'restore', + 'Pass': 'Abracadabra', + }, + { 'IP': '10.0.0.11', + 'Name': 'ServerTwo', + 'Mounted': False, + 'Share': 'Backups', + 'User': 'restore', + 'Pass': 'Abracadabra', + }, +] +CLIENT_INFO_SERVER = { + 'IP': '10.0.0.10', + 'RegEntry': r'0x10001,0xcc674aebbd889f5fd553564adcf3cab550791eca12542033d52134db893c95aabb6b318a4621d8116f6838d873edfe9db4509e1dfc9177ee7484808a62cbc42b913387f694fd67e81950f85198acf721c5767b54db7b864d69cce65e12c78c87d0fb4fc54996609c9b9274b1de7bae2f95000c9ca8d7e3f9b3f2cdb21cd578adf9ba98d10400a8203bb1a879a4cd2fad99baeb12738b9b4b99fec821f881acb62598a43c059f74af287bc8dceeb4821317aa44e2e0ee66d346927a654c702854a71a2eaed6a53f6be9360c7049974a2597a548361da42ac982ae55f993700a8b1fc9f3b4458314fbd41f239de0a29716cdcefbbb2c8d02b4c2effa4163cfeac9', + 'Share': '/srv/ClientInfo', + 'User': 'upload', +} +OFFICE_SERVER = { + 'IP': OFFICE_SERVER_IP, + 'Name': 'ServerOne', + 'Mounted': False, + 'Share': 'Office', + 'User': 'restore', + 'Pass': 'Abracadabra', +} +QUICKBOOKS_SERVER = { + 'IP': QUICKBOOKS_SERVER_IP, + 'Name': 'ServerOne', + 'Mounted': False, + 'Share': 'QuickBooks', + 'User': 'restore', + 'Pass': 'Abracadabra', +} +WINDOWS_SERVER = { + 'IP': '10.0.0.10', + 'Name': 'ServerOne', + 'Mounted': False, + 'Share': 'Windows', + 'User': 'restore', + 'Pass': 'Abracadabra', +} + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/settings/music.py b/.bin/Scripts/settings/music.py index a2d49f31..80c71086 100644 --- a/.bin/Scripts/settings/music.py +++ b/.bin/Scripts/settings/music.py @@ -1,70 +1,70 @@ -# Wizard Kit: Settings - Music - -MUSIC_MOD = [ - '104208#banana_boat.mod', - '114971#tilbury_fair.mod', - '132563#ufo_tune.mod', - '135906#magnetik_girl.xm', - '140628#autumn_in_budapest.xm', - '143198#summer_memories_3.xm', - '144405#hillbilly_billyboy.xm', - '154795#4mat_-_eternity.xm', - '155845#bookworm.mo3', - '155914#battleofsteel.xm', - '158975#1_channel_moog.it', - '165495#trans.s3m', - '168513#necros_-_introspection.s3m', - '169628#radix_-_feng_shui_schematics.xm', - '175238#unknown48_-_twilight.mod', - '33432#ambrozia.xm', - '33460#amigatre.mod', - '34594#CHARIOT.S3M', - '34596#BUTTERFL.XM', - '34654#CTGOBLIN.S3M', - '35151#bananasplit.mod', - '35280#DEADLOCK.XM', - '38591#compo_liam.xm', - '39987#crystald.s3m', - '40475#ELYSIUM.MOD', - '42146#enigma.mod', - '42519#GHOST2.MOD', - '42560#GSLINGER.MOD', - '42872#existing.xm', - '50427#nf-stven.xm', - '51549#overture.mod', - '54250#SATELL.S3M', - '54313#realmk.s3m', - '55789#scrambld.mod', - '57934#spacedeb.mod', - '59344#stardstm.mod', - '60395#2ND_PM.S3M', - '66187#external.xm', - '66343#beek-substitutionology.it', - '67561#radix-unreal_superhero.xm', - '70829#inside_out.s3m', - '83779#beyond_music.mod', - ] - -MUSIC_SNES = [ - 'actr', - 'crock', - 'ct', - 'dkc', - 'dkq', - 'ff6', - 'fz', - 'loz3', - 'mmx', - 'ptws', - 'scv4', - 'sf', - 'sf2', - 'sgng', - 'smk', - 'smw', - 'yi', - 'zamn' - ] - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Settings - Music + +MUSIC_MOD = [ + '104208#banana_boat.mod', + '114971#tilbury_fair.mod', + '132563#ufo_tune.mod', + '135906#magnetik_girl.xm', + '140628#autumn_in_budapest.xm', + '143198#summer_memories_3.xm', + '144405#hillbilly_billyboy.xm', + '154795#4mat_-_eternity.xm', + '155845#bookworm.mo3', + '155914#battleofsteel.xm', + '158975#1_channel_moog.it', + '165495#trans.s3m', + '168513#necros_-_introspection.s3m', + '169628#radix_-_feng_shui_schematics.xm', + '175238#unknown48_-_twilight.mod', + '33432#ambrozia.xm', + '33460#amigatre.mod', + '34594#CHARIOT.S3M', + '34596#BUTTERFL.XM', + '34654#CTGOBLIN.S3M', + '35151#bananasplit.mod', + '35280#DEADLOCK.XM', + '38591#compo_liam.xm', + '39987#crystald.s3m', + '40475#ELYSIUM.MOD', + '42146#enigma.mod', + '42519#GHOST2.MOD', + '42560#GSLINGER.MOD', + '42872#existing.xm', + '50427#nf-stven.xm', + '51549#overture.mod', + '54250#SATELL.S3M', + '54313#realmk.s3m', + '55789#scrambld.mod', + '57934#spacedeb.mod', + '59344#stardstm.mod', + '60395#2ND_PM.S3M', + '66187#external.xm', + '66343#beek-substitutionology.it', + '67561#radix-unreal_superhero.xm', + '70829#inside_out.s3m', + '83779#beyond_music.mod', + ] + +MUSIC_SNES = [ + 'actr', + 'crock', + 'ct', + 'dkc', + 'dkq', + 'ff6', + 'fz', + 'loz3', + 'mmx', + 'ptws', + 'scv4', + 'sf', + 'sf2', + 'sgng', + 'smk', + 'smw', + 'yi', + 'zamn' + ] + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/settings/sources.py b/.bin/Scripts/settings/sources.py index 1e705d9e..f7fcce36 100644 --- a/.bin/Scripts/settings/sources.py +++ b/.bin/Scripts/settings/sources.py @@ -1,203 +1,203 @@ -# Wizard Kit: Settings - Sources - -SOURCE_URLS = { - 'AIDA64': 'http://download.aida64.com/aida64engineer592.zip', - 'Adobe Reader DC': 'http://ardownload.adobe.com/pub/adobe/reader/win/AcrobatDC/1800920044/AcroRdrDC1800920044_en_US.exe', - 'AdwCleaner': 'https://toolslib.net/downloads/finish/1-adwcleaner/', - 'Autoruns': 'https://download.sysinternals.com/files/Autoruns.zip', - 'BleachBit': 'https://download.bleachbit.org/beta/1.17/BleachBit-1.17-portable.zip', - 'BlueScreenView32': 'http://www.nirsoft.net/utils/bluescreenview.zip', - 'BlueScreenView64': 'http://www.nirsoft.net/utils/bluescreenview-x64.zip', - 'Caffeine': 'http://www.zhornsoftware.co.uk/caffeine/caffeine.zip', - 'ClassicStartSkin': 'http://www.classicshell.net/forum/download/file.php?id=3001&sid=9a195960d98fd754867dcb63d9315335', - 'Du': 'https://download.sysinternals.com/files/DU.zip', - 'ERUNT': 'http://www.aumha.org/downloads/erunt.zip', - 'Everything32': 'https://www.voidtools.com/Everything-1.4.1.877.x86.zip', - 'Everything64': 'https://www.voidtools.com/Everything-1.4.1.877.x64.zip', - 'FastCopy32': 'http://ftp.vector.co.jp/69/28/2323/FastCopy332.zip', - 'FastCopy64': 'http://ftp.vector.co.jp/69/28/2323/FastCopy332_x64.zip', - 'Firefox uBO': 'https://addons.mozilla.org/firefox/downloads/file/764482/ublock_origin-1.14.18-an+fx.xpi?src=dp-btn-primary', - 'HWiNFO32': 'http://app.oldfoss.com:81/download/HWiNFO/hw32_560.zip', - 'HWiNFO64': 'http://app.oldfoss.com:81/download/HWiNFO/hw64_560.zip', - 'HitmanPro32': 'https://dl.surfright.nl/HitmanPro.exe', - 'HitmanPro64': 'https://dl.surfright.nl/HitmanPro_x64.exe', - 'IOBit_Uninstaller': 'https://portableapps.com/redirect/?a=IObitUninstallerPortable&t=http%3A%2F%2Fdownloads.portableapps.com%2Fportableapps%2Fiobituninstallerportable%2FIObitUninstallerPortable_7.0.2.49.paf.exe', - 'Intel SSD Toolbox': r'https://downloadmirror.intel.com/27330/eng/Intel%20SSD%20Toolbox%20-%20v3.4.9.exe', - 'KVRT': 'http://devbuilds.kaspersky-labs.com/devbuilds/KVRT/latest/full/KVRT.exe', - 'NotepadPlusPlus': 'https://notepad-plus-plus.org/repository/7.x/7.5.1/npp.7.5.1.bin.minimalist.7z', - 'Office Deployment Tool 2013': 'https://download.microsoft.com/download/6/2/3/6230F7A2-D8A9-478B-AC5C-57091B632FCF/officedeploymenttool_x86_4827-1000.exe', - 'Office Deployment Tool 2016': 'https://download.microsoft.com/download/2/7/A/27AF1BE6-DD20-4CB4-B154-EBAB8A7D4A7E/officedeploymenttool_8529.3600.exe', - 'ProduKey32': 'http://www.nirsoft.net/utils/produkey.zip', - 'ProduKey64': 'http://www.nirsoft.net/utils/produkey-x64.zip', - 'PuTTY': 'https://the.earth.li/~sgtatham/putty/latest/w32/putty.zip', - 'RKill': 'https://www.bleepingcomputer.com/download/rkill/dl/10/', - 'SDIO Themes': 'http://snappy-driver-installer.org/downloads/SDIO_Themes.zip', - 'SDIO Torrent': 'http://snappy-driver-installer.org/downloads/SDIO_Update.torrent', - 'Samsung Magician': 'http://downloadcenter.samsung.com/content/SW/201710/20171019164455812/Samsung_Magician_Installer.exe', - 'TDSSKiller': 'https://media.kaspersky.com/utilities/VirusUtilities/EN/tdsskiller.exe', - 'TestDisk': 'https://www.cgsecurity.org/testdisk-7.1-WIP.win.zip', - 'TreeSizeFree': 'https://www.jam-software.com/treesize_free/TreeSizeFree-Portable.zip', - 'wimlib32': 'https://wimlib.net/downloads/wimlib-1.12.0-windows-i686-bin.zip', - 'wimlib64': 'https://wimlib.net/downloads/wimlib-1.12.0-windows-x86_64-bin.zip', - 'Winapp2': 'https://github.com/MoscaDotTo/Winapp2/archive/master.zip', - 'XMPlay 7z': 'http://support.xmplay.com/files/16/xmp-7z.zip?v=800962', - 'XMPlay Game': 'http://support.xmplay.com/files/12/xmp-gme.zip?v=515637', - 'XMPlay RAR': 'http://support.xmplay.com/files/16/xmp-rar.zip?v=409646', - 'XMPlay WAModern': 'http://support.xmplay.com/files/10/WAModern.zip?v=207099', - 'XMPlay': 'http://support.xmplay.com/files/20/xmplay3823.zip?v=115916', - 'XYplorerFree': 'https://www.xyplorer.com/download/xyplorer_free_noinstall.zip', - 'aria2': 'https://github.com/aria2/aria2/releases/download/release-1.33.1/aria2-1.33.1-win-32bit-build1.zip', - } -VCREDIST_SOURCES = { - '2008sp1': { - '32': 'https://download.microsoft.com/download/5/D/8/5D8C65CB-C849-4025-8E95-C3966CAFD8AE/vcredist_x86.exe', - '64': 'https://download.microsoft.com/download/5/D/8/5D8C65CB-C849-4025-8E95-C3966CAFD8AE/vcredist_x64.exe', - }, - '2010sp1': { - '32': 'https://download.microsoft.com/download/1/6/5/165255E7-1014-4D0A-B094-B6A430A6BFFC/vcredist_x86.exe', - '64': 'https://download.microsoft.com/download/1/6/5/165255E7-1014-4D0A-B094-B6A430A6BFFC/vcredist_x64.exe', - }, - '2012u4': { - '32': 'https://download.microsoft.com/download/1/6/B/16B06F60-3B20-4FF2-B699-5E9B7962F9AE/VSU_4/vcredist_x86.exe', - '64': 'https://download.microsoft.com/download/1/6/B/16B06F60-3B20-4FF2-B699-5E9B7962F9AE/VSU_4/vcredist_x64.exe', - }, - '2013': { - '32': 'https://download.microsoft.com/download/0/5/6/056dcda9-d667-4e27-8001-8a0c6971d6b1/vcredist_x86.exe', - '64': 'https://download.microsoft.com/download/0/5/6/056dcda9-d667-4e27-8001-8a0c6971d6b1/vcredist_x64.exe', - }, - '2017': { - '32': 'https://download.visualstudio.microsoft.com/download/pr/11100229/78c1e864d806e36f6035d80a0e80399e/VC_redist.x86.exe', - '64': 'https://download.visualstudio.microsoft.com/download/pr/11100230/15ccb3f02745c7b206ad10373cbca89b/VC_redist.x64.exe', - }, - } -NINITE_SOURCES = { - 'Bundles': { - 'Runtimes.exe': '.net4.7-air-java8-silverlight', - 'Legacy.exe': '.net4.7-7zip-air-chrome-firefox-java8-silverlight-vlc', - 'Modern.exe': '.net4.7-7zip-air-chrome-classicstart-firefox-java8-silverlight-vlc', - }, - 'Audio-Video': { - 'AIMP.exe': 'aimp', - 'Audacity.exe': 'audacity', - 'CCCP.exe': 'cccp', - 'Foobar2000.exe': 'foobar', - 'GOM.exe': 'gom', - 'HandBrake.exe': 'handbrake', - 'iTunes.exe': 'itunes', - 'K-Lite Codecs.exe': 'klitecodecs', - 'MediaMonkey.exe': 'mediamonkey', - 'MusicBee.exe': 'musicbee', - 'Spotify.exe': 'spotify', - 'VLC.exe': 'vlc', - 'Winamp.exe': 'winamp', - }, - 'Cloud Storage': { - 'Dropbox.exe': 'dropbox', - 'Google Backup & Sync.exe': 'googlebackupandsync', - 'Mozy.exe': 'mozy', - 'OneDrive.exe': 'onedrive', - 'SugarSync.exe': 'sugarsync', - }, - 'Communication': { - 'Pidgin.exe': 'pidgin', - 'Skype.exe': 'skype', - 'Trillian.exe': 'trillian', - }, - 'Compression': { - '7-Zip.exe': '7zip', - 'PeaZip.exe': 'peazip', - 'WinRAR.exe': 'winrar', - }, - 'Developer': { - 'Eclipse.exe': 'eclipse', - 'FileZilla.exe': 'filezilla', - 'JDK 8.exe': 'jdk8', - 'JDK 8 (x64).exe': 'jdkx8', - 'Notepad++.exe': 'notepadplusplus', - 'PuTTY.exe': 'putty', - 'Python 2.exe': 'python', - 'Visual Studio Code.exe': 'vscode', - 'WinMerge.exe': 'winmerge', - 'WinSCP.exe': 'winscp', - }, - 'File Sharing': { - 'qBittorrent.exe': 'qbittorrent', - }, - 'Image-Photo': { - 'Blender.exe': 'blender', - 'FastStone.exe': 'faststone', - 'GIMP.exe': 'gimp', - 'Greenshot.exe': 'greenshot', - 'Inkscape.exe': 'inkscape', - 'IrfanView.exe': 'irfanview', - 'Krita.exe': 'krita', - 'Paint.NET.exe': 'paint.net', - 'ShareX.exe': 'sharex', - 'XnView.exe': 'xnview', - }, - 'Misc': { - 'Evernote.exe': 'evernote', - 'Everything.exe': 'everything', - 'KeePass 2.exe': 'keepass2', - 'Google Earth.exe': 'googleearth', - 'NV Access.exe': 'nvda', - 'Steam.exe': 'steam', - }, - 'Office': { - 'CutePDF.exe': 'cutepdf', - 'Foxit Reader.exe': 'foxit', - 'LibreOffice.exe': 'libreoffice', - 'OpenOffice.exe': 'openoffice', - 'PDFCreator.exe': 'pdfcreator', - 'SumatraPDF.exe': 'sumatrapdf', - 'Thunderbird.exe': 'thunderbird', - }, - 'Runtimes': { - 'Adobe Air.exe': 'air', - 'dotNET.exe': '.net4.7', - 'Java 8.exe': 'java8', - 'Shockwave.exe': 'shockwave', - 'Silverlight.exe': 'silverlight', - }, - 'Security': { - 'Avast.exe': 'avast', - 'AVG.exe': 'avg', - 'Avira.exe': 'avira', - 'Microsoft Security Essentials.exe': 'essentials', - 'Malwarebytes Anti-Malware.exe': 'malwarebytes', - 'Spybot 2.exe': 'spybot2', - 'SUPERAntiSpyware.exe': 'super', - }, - 'Utilities': { - 'CDBurnerXP.exe': 'cdburnerxp', - 'Classic Start.exe': 'classicstart', - 'Glary Utilities.exe': 'glary', - 'ImgBurn.exe': 'imgburn', - 'InfraRecorder.exe': 'infrarecorder', - 'Launchy.exe': 'launchy', - 'RealVNC.exe': 'realvnc', - 'Revo Uninstaller.exe': 'revo', - 'TeamViewer 12.exe': 'teamviewer12', - 'TeraCopy.exe': 'teracopy', - 'WinDirStat.exe': 'windirstat', - }, - 'Web Browsers': { - 'Google Chrome.exe': 'chrome', - 'Mozilla Firefox.exe': 'firefox', - 'Opera Chromium.exe': 'operaChromium', - }, - } -RST_SOURCES = { - #SetupRST_12.0.exe : Removed from download center? - #SetupRST_12.5.exe : Removed from download center? - #SetupRST_12.8.exe : Removed from download center? - 'SetupRST_12.9.exe': 'https://downloadmirror.intel.com/23496/eng/SetupRST.exe', - #SetupRST_13.x.exe : Broken, doesn't support > .NET 4.5 - 'SetupRST_14.0.exe': 'https://downloadmirror.intel.com/25091/eng/SetupRST.exe', - 'SetupRST_14.8.exe': 'https://downloadmirror.intel.com/26759/eng/setuprst.exe', - 'SetupRST_15.8.exe': 'https://downloadmirror.intel.com/27147/eng/SetupRST.exe', - } - - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Settings - Sources + +SOURCE_URLS = { + 'AIDA64': 'http://download.aida64.com/aida64engineer592.zip', + 'Adobe Reader DC': 'http://ardownload.adobe.com/pub/adobe/reader/win/AcrobatDC/1800920044/AcroRdrDC1800920044_en_US.exe', + 'AdwCleaner': 'https://toolslib.net/downloads/finish/1-adwcleaner/', + 'Autoruns': 'https://download.sysinternals.com/files/Autoruns.zip', + 'BleachBit': 'https://download.bleachbit.org/beta/1.17/BleachBit-1.17-portable.zip', + 'BlueScreenView32': 'http://www.nirsoft.net/utils/bluescreenview.zip', + 'BlueScreenView64': 'http://www.nirsoft.net/utils/bluescreenview-x64.zip', + 'Caffeine': 'http://www.zhornsoftware.co.uk/caffeine/caffeine.zip', + 'ClassicStartSkin': 'http://www.classicshell.net/forum/download/file.php?id=3001&sid=9a195960d98fd754867dcb63d9315335', + 'Du': 'https://download.sysinternals.com/files/DU.zip', + 'ERUNT': 'http://www.aumha.org/downloads/erunt.zip', + 'Everything32': 'https://www.voidtools.com/Everything-1.4.1.877.x86.zip', + 'Everything64': 'https://www.voidtools.com/Everything-1.4.1.877.x64.zip', + 'FastCopy32': 'http://ftp.vector.co.jp/69/28/2323/FastCopy332.zip', + 'FastCopy64': 'http://ftp.vector.co.jp/69/28/2323/FastCopy332_x64.zip', + 'Firefox uBO': 'https://addons.mozilla.org/firefox/downloads/file/764482/ublock_origin-1.14.18-an+fx.xpi?src=dp-btn-primary', + 'HWiNFO32': 'http://app.oldfoss.com:81/download/HWiNFO/hw32_560.zip', + 'HWiNFO64': 'http://app.oldfoss.com:81/download/HWiNFO/hw64_560.zip', + 'HitmanPro32': 'https://dl.surfright.nl/HitmanPro.exe', + 'HitmanPro64': 'https://dl.surfright.nl/HitmanPro_x64.exe', + 'IOBit_Uninstaller': 'https://portableapps.com/redirect/?a=IObitUninstallerPortable&t=http%3A%2F%2Fdownloads.portableapps.com%2Fportableapps%2Fiobituninstallerportable%2FIObitUninstallerPortable_7.0.2.49.paf.exe', + 'Intel SSD Toolbox': r'https://downloadmirror.intel.com/27330/eng/Intel%20SSD%20Toolbox%20-%20v3.4.9.exe', + 'KVRT': 'http://devbuilds.kaspersky-labs.com/devbuilds/KVRT/latest/full/KVRT.exe', + 'NotepadPlusPlus': 'https://notepad-plus-plus.org/repository/7.x/7.5.1/npp.7.5.1.bin.minimalist.7z', + 'Office Deployment Tool 2013': 'https://download.microsoft.com/download/6/2/3/6230F7A2-D8A9-478B-AC5C-57091B632FCF/officedeploymenttool_x86_4827-1000.exe', + 'Office Deployment Tool 2016': 'https://download.microsoft.com/download/2/7/A/27AF1BE6-DD20-4CB4-B154-EBAB8A7D4A7E/officedeploymenttool_8529.3600.exe', + 'ProduKey32': 'http://www.nirsoft.net/utils/produkey.zip', + 'ProduKey64': 'http://www.nirsoft.net/utils/produkey-x64.zip', + 'PuTTY': 'https://the.earth.li/~sgtatham/putty/latest/w32/putty.zip', + 'RKill': 'https://www.bleepingcomputer.com/download/rkill/dl/10/', + 'SDIO Themes': 'http://snappy-driver-installer.org/downloads/SDIO_Themes.zip', + 'SDIO Torrent': 'http://snappy-driver-installer.org/downloads/SDIO_Update.torrent', + 'Samsung Magician': 'http://downloadcenter.samsung.com/content/SW/201710/20171019164455812/Samsung_Magician_Installer.exe', + 'TDSSKiller': 'https://media.kaspersky.com/utilities/VirusUtilities/EN/tdsskiller.exe', + 'TestDisk': 'https://www.cgsecurity.org/testdisk-7.1-WIP.win.zip', + 'TreeSizeFree': 'https://www.jam-software.com/treesize_free/TreeSizeFree-Portable.zip', + 'wimlib32': 'https://wimlib.net/downloads/wimlib-1.12.0-windows-i686-bin.zip', + 'wimlib64': 'https://wimlib.net/downloads/wimlib-1.12.0-windows-x86_64-bin.zip', + 'Winapp2': 'https://github.com/MoscaDotTo/Winapp2/archive/master.zip', + 'XMPlay 7z': 'http://support.xmplay.com/files/16/xmp-7z.zip?v=800962', + 'XMPlay Game': 'http://support.xmplay.com/files/12/xmp-gme.zip?v=515637', + 'XMPlay RAR': 'http://support.xmplay.com/files/16/xmp-rar.zip?v=409646', + 'XMPlay WAModern': 'http://support.xmplay.com/files/10/WAModern.zip?v=207099', + 'XMPlay': 'http://support.xmplay.com/files/20/xmplay3823.zip?v=115916', + 'XYplorerFree': 'https://www.xyplorer.com/download/xyplorer_free_noinstall.zip', + 'aria2': 'https://github.com/aria2/aria2/releases/download/release-1.33.1/aria2-1.33.1-win-32bit-build1.zip', + } +VCREDIST_SOURCES = { + '2008sp1': { + '32': 'https://download.microsoft.com/download/5/D/8/5D8C65CB-C849-4025-8E95-C3966CAFD8AE/vcredist_x86.exe', + '64': 'https://download.microsoft.com/download/5/D/8/5D8C65CB-C849-4025-8E95-C3966CAFD8AE/vcredist_x64.exe', + }, + '2010sp1': { + '32': 'https://download.microsoft.com/download/1/6/5/165255E7-1014-4D0A-B094-B6A430A6BFFC/vcredist_x86.exe', + '64': 'https://download.microsoft.com/download/1/6/5/165255E7-1014-4D0A-B094-B6A430A6BFFC/vcredist_x64.exe', + }, + '2012u4': { + '32': 'https://download.microsoft.com/download/1/6/B/16B06F60-3B20-4FF2-B699-5E9B7962F9AE/VSU_4/vcredist_x86.exe', + '64': 'https://download.microsoft.com/download/1/6/B/16B06F60-3B20-4FF2-B699-5E9B7962F9AE/VSU_4/vcredist_x64.exe', + }, + '2013': { + '32': 'https://download.microsoft.com/download/0/5/6/056dcda9-d667-4e27-8001-8a0c6971d6b1/vcredist_x86.exe', + '64': 'https://download.microsoft.com/download/0/5/6/056dcda9-d667-4e27-8001-8a0c6971d6b1/vcredist_x64.exe', + }, + '2017': { + '32': 'https://download.visualstudio.microsoft.com/download/pr/11100229/78c1e864d806e36f6035d80a0e80399e/VC_redist.x86.exe', + '64': 'https://download.visualstudio.microsoft.com/download/pr/11100230/15ccb3f02745c7b206ad10373cbca89b/VC_redist.x64.exe', + }, + } +NINITE_SOURCES = { + 'Bundles': { + 'Runtimes.exe': '.net4.7-air-java8-silverlight', + 'Legacy.exe': '.net4.7-7zip-air-chrome-firefox-java8-silverlight-vlc', + 'Modern.exe': '.net4.7-7zip-air-chrome-classicstart-firefox-java8-silverlight-vlc', + }, + 'Audio-Video': { + 'AIMP.exe': 'aimp', + 'Audacity.exe': 'audacity', + 'CCCP.exe': 'cccp', + 'Foobar2000.exe': 'foobar', + 'GOM.exe': 'gom', + 'HandBrake.exe': 'handbrake', + 'iTunes.exe': 'itunes', + 'K-Lite Codecs.exe': 'klitecodecs', + 'MediaMonkey.exe': 'mediamonkey', + 'MusicBee.exe': 'musicbee', + 'Spotify.exe': 'spotify', + 'VLC.exe': 'vlc', + 'Winamp.exe': 'winamp', + }, + 'Cloud Storage': { + 'Dropbox.exe': 'dropbox', + 'Google Backup & Sync.exe': 'googlebackupandsync', + 'Mozy.exe': 'mozy', + 'OneDrive.exe': 'onedrive', + 'SugarSync.exe': 'sugarsync', + }, + 'Communication': { + 'Pidgin.exe': 'pidgin', + 'Skype.exe': 'skype', + 'Trillian.exe': 'trillian', + }, + 'Compression': { + '7-Zip.exe': '7zip', + 'PeaZip.exe': 'peazip', + 'WinRAR.exe': 'winrar', + }, + 'Developer': { + 'Eclipse.exe': 'eclipse', + 'FileZilla.exe': 'filezilla', + 'JDK 8.exe': 'jdk8', + 'JDK 8 (x64).exe': 'jdkx8', + 'Notepad++.exe': 'notepadplusplus', + 'PuTTY.exe': 'putty', + 'Python 2.exe': 'python', + 'Visual Studio Code.exe': 'vscode', + 'WinMerge.exe': 'winmerge', + 'WinSCP.exe': 'winscp', + }, + 'File Sharing': { + 'qBittorrent.exe': 'qbittorrent', + }, + 'Image-Photo': { + 'Blender.exe': 'blender', + 'FastStone.exe': 'faststone', + 'GIMP.exe': 'gimp', + 'Greenshot.exe': 'greenshot', + 'Inkscape.exe': 'inkscape', + 'IrfanView.exe': 'irfanview', + 'Krita.exe': 'krita', + 'Paint.NET.exe': 'paint.net', + 'ShareX.exe': 'sharex', + 'XnView.exe': 'xnview', + }, + 'Misc': { + 'Evernote.exe': 'evernote', + 'Everything.exe': 'everything', + 'KeePass 2.exe': 'keepass2', + 'Google Earth.exe': 'googleearth', + 'NV Access.exe': 'nvda', + 'Steam.exe': 'steam', + }, + 'Office': { + 'CutePDF.exe': 'cutepdf', + 'Foxit Reader.exe': 'foxit', + 'LibreOffice.exe': 'libreoffice', + 'OpenOffice.exe': 'openoffice', + 'PDFCreator.exe': 'pdfcreator', + 'SumatraPDF.exe': 'sumatrapdf', + 'Thunderbird.exe': 'thunderbird', + }, + 'Runtimes': { + 'Adobe Air.exe': 'air', + 'dotNET.exe': '.net4.7', + 'Java 8.exe': 'java8', + 'Shockwave.exe': 'shockwave', + 'Silverlight.exe': 'silverlight', + }, + 'Security': { + 'Avast.exe': 'avast', + 'AVG.exe': 'avg', + 'Avira.exe': 'avira', + 'Microsoft Security Essentials.exe': 'essentials', + 'Malwarebytes Anti-Malware.exe': 'malwarebytes', + 'Spybot 2.exe': 'spybot2', + 'SUPERAntiSpyware.exe': 'super', + }, + 'Utilities': { + 'CDBurnerXP.exe': 'cdburnerxp', + 'Classic Start.exe': 'classicstart', + 'Glary Utilities.exe': 'glary', + 'ImgBurn.exe': 'imgburn', + 'InfraRecorder.exe': 'infrarecorder', + 'Launchy.exe': 'launchy', + 'RealVNC.exe': 'realvnc', + 'Revo Uninstaller.exe': 'revo', + 'TeamViewer 12.exe': 'teamviewer12', + 'TeraCopy.exe': 'teracopy', + 'WinDirStat.exe': 'windirstat', + }, + 'Web Browsers': { + 'Google Chrome.exe': 'chrome', + 'Mozilla Firefox.exe': 'firefox', + 'Opera Chromium.exe': 'operaChromium', + }, + } +RST_SOURCES = { + #SetupRST_12.0.exe : Removed from download center? + #SetupRST_12.5.exe : Removed from download center? + #SetupRST_12.8.exe : Removed from download center? + 'SetupRST_12.9.exe': 'https://downloadmirror.intel.com/23496/eng/SetupRST.exe', + #SetupRST_13.x.exe : Broken, doesn't support > .NET 4.5 + 'SetupRST_14.0.exe': 'https://downloadmirror.intel.com/25091/eng/SetupRST.exe', + 'SetupRST_14.8.exe': 'https://downloadmirror.intel.com/26759/eng/setuprst.exe', + 'SetupRST_15.8.exe': 'https://downloadmirror.intel.com/27147/eng/SetupRST.exe', + } + + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/settings/tools.py b/.bin/Scripts/settings/tools.py index f8fe7737..d678027d 100644 --- a/.bin/Scripts/settings/tools.py +++ b/.bin/Scripts/settings/tools.py @@ -1,55 +1,55 @@ -# Wizard Kit: Settings - Tools - -TOOLS = { - # NOTE: BinDir will be prepended to these paths at runtime - 'AIDA64': { - '32': r'AIDA64\aida64.exe'}, - 'AutoRuns': { - '32': r'Autoruns\autoruns.exe', - '64': r'Autoruns\autoruns64.exe'}, - 'BleachBit': { - '32': r'BleachBit\bleachbit_console.exe'}, - 'Caffeine': { - '32': r'Caffeine\caffeine.exe'}, - 'Du': { - '32': r'Du\du.exe', - '64': r'Du\du64.exe'}, - 'ERUNT': { - '32': r'ERUNT\ERUNT.EXE'}, - 'Everything': { - '32': r'Everything\Everything.exe', - '64': r'Everything\Everything64.exe'}, - 'FastCopy': { - '32': r'FastCopy\FastCopy.exe', - '64': r'FastCopy\FastCopy64.exe'}, - 'HitmanPro': { - '32': r'HitmanPro\HitmanPro.exe', - '64': r'HitmanPro\HitmanPro64.exe'}, - 'HWiNFO': { - '32': r'HWiNFO\HWiNFO.exe', - '64': r'HWiNFO\HWiNFO64.exe'}, - 'KVRT': { - '32': r'KVRT\KVRT.exe'}, - 'NotepadPlusPlus': { - '32': r'NotepadPlusPlus\notepadplusplus.exe'}, - 'ProduKey': { - '32': r'ProduKey\ProduKey.exe', - '64': r'ProduKey\ProduKey64.exe'}, - 'PuTTY-PSFTP': { - '32': r'PuTTY\PSFTP.EXE'}, - 'RKill': { - '32': r'RKill\RKill.exe'}, - 'SevenZip': { - '32': r'7-Zip\7za.exe', - '64': r'7-Zip\7za64.exe'}, - 'TDSSKiller': { - '32': r'TDSSKiller\TDSSKiller.exe'}, - 'wimlib-imagex': { - '32': r'wimlib\x32\wimlib-imagex.exe', - '64': r'wimlib\x64\wimlib-imagex.exe'}, - 'XMPlay': { - '32': r'XMPlay\xmplay.exe'}, - } - -if __name__ == '__main__': - print("This file is not meant to be called directly.") +# Wizard Kit: Settings - Tools + +TOOLS = { + # NOTE: BinDir will be prepended to these paths at runtime + 'AIDA64': { + '32': r'AIDA64\aida64.exe'}, + 'AutoRuns': { + '32': r'Autoruns\autoruns.exe', + '64': r'Autoruns\autoruns64.exe'}, + 'BleachBit': { + '32': r'BleachBit\bleachbit_console.exe'}, + 'Caffeine': { + '32': r'Caffeine\caffeine.exe'}, + 'Du': { + '32': r'Du\du.exe', + '64': r'Du\du64.exe'}, + 'ERUNT': { + '32': r'ERUNT\ERUNT.EXE'}, + 'Everything': { + '32': r'Everything\Everything.exe', + '64': r'Everything\Everything64.exe'}, + 'FastCopy': { + '32': r'FastCopy\FastCopy.exe', + '64': r'FastCopy\FastCopy64.exe'}, + 'HitmanPro': { + '32': r'HitmanPro\HitmanPro.exe', + '64': r'HitmanPro\HitmanPro64.exe'}, + 'HWiNFO': { + '32': r'HWiNFO\HWiNFO.exe', + '64': r'HWiNFO\HWiNFO64.exe'}, + 'KVRT': { + '32': r'KVRT\KVRT.exe'}, + 'NotepadPlusPlus': { + '32': r'NotepadPlusPlus\notepadplusplus.exe'}, + 'ProduKey': { + '32': r'ProduKey\ProduKey.exe', + '64': r'ProduKey\ProduKey64.exe'}, + 'PuTTY-PSFTP': { + '32': r'PuTTY\PSFTP.EXE'}, + 'RKill': { + '32': r'RKill\RKill.exe'}, + 'SevenZip': { + '32': r'7-Zip\7za.exe', + '64': r'7-Zip\7za64.exe'}, + 'TDSSKiller': { + '32': r'TDSSKiller\TDSSKiller.exe'}, + 'wimlib-imagex': { + '32': r'wimlib\x32\wimlib-imagex.exe', + '64': r'wimlib\x64\wimlib-imagex.exe'}, + 'XMPlay': { + '32': r'XMPlay\xmplay.exe'}, + } + +if __name__ == '__main__': + print("This file is not meant to be called directly.") diff --git a/.bin/Scripts/sfc_scan.py b/.bin/Scripts/sfc_scan.py index 913c4025..d99f4cf2 100644 --- a/.bin/Scripts/sfc_scan.py +++ b/.bin/Scripts/sfc_scan.py @@ -1,39 +1,39 @@ -# Wizard Kit: Check, and possibly repair, system file health via SFC - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.repairs import * -init_global_vars() -os.system('title {}: SFC Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\SFC Tool.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: SFC Tool\n'.format(KIT_NAME_FULL)) - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }, - 'Warning': { - 'GenericRepair': 'Repaired', - }} - if ask('Run a SFC scan now?'): - try_and_print(message='SFC scan...', - function=run_sfc_scan, other_results=other_results) - else: - abort() - - # Done - print_standard('\nDone.') - pause('Press Enter to exit...') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Check, and possibly repair, system file health via SFC + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.repairs import * +init_global_vars() +os.system('title {}: SFC Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\SFC Tool.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: SFC Tool\n'.format(KIT_NAME_FULL)) + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }, + 'Warning': { + 'GenericRepair': 'Repaired', + }} + if ask('Run a SFC scan now?'): + try_and_print(message='SFC scan...', + function=run_sfc_scan, other_results=other_results) + else: + abort() + + # Done + print_standard('\nDone.') + pause('Press Enter to exit...') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/system_checklist.py b/.bin/Scripts/system_checklist.py index 4ba60db3..a5c9896f 100644 --- a/.bin/Scripts/system_checklist.py +++ b/.bin/Scripts/system_checklist.py @@ -1,106 +1,106 @@ -# Wizard Kit: System Checklist - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.cleanup import * -from functions.diags import * -from functions.info import * -from functions.product_keys import * -from functions.setup import * -init_global_vars() -os.system('title {}: System Checklist Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\System Checklist.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: System Checklist Tool\n'.format(KIT_NAME_FULL)) - ticket_number = get_ticket_number() - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - 'BIOSKeyNotFoundError': 'BIOS key not found', - }, - 'Warning': {}} - print_info('Starting System Checklist for Ticket #{}\n'.format( - ticket_number)) - - # Configure - print_info('Configure') - if global_vars['OS']['Version'] == '10': - try_and_print(message='Explorer...', - function=config_explorer_system, cs='Done') - try_and_print(message='Updating Clock...', - function=update_clock, cs='Done') - - # Cleanup - print_info('Cleanup') - try_and_print(message='Desktop...', - function=cleanup_desktop, cs='Done') - try_and_print(message='AdwCleaner...', - function=cleanup_adwcleaner, cs='Done') - - # Export system info - print_info('Backup System Information') - try_and_print(message='AIDA64 reports...', - function=run_aida64, cs='Done') - try_and_print(message='File listing...', - function=backup_file_list, cs='Done') - try_and_print(message='Power plans...', - function=backup_power_plans, cs='Done') - try_and_print(message='Product Keys...', - function=run_produkey, cs='Done') - try_and_print(message='Registry...', - function=backup_registry, cs='Done') - - # User data - print_info('User Data') - show_user_data_summary() - - # Summary - print_info('Summary') - try_and_print(message='Operating System:', - function=show_os_name, ns='Unknown', silent_function=False) - try_and_print(message='Activation:', - function=show_os_activation, ns='Unknown', silent_function=False) - if (not windows_is_activated() - and global_vars['OS']['Version'] in ('8', '10')): - try_and_print(message='BIOS Activation:', - function=activate_windows_with_bios, - other_results=other_results) - try_and_print(message='Installed Office:', - function=get_installed_office, ns='Unknown', print_return=True) - show_free_space() - try_and_print(message='Installed RAM:', - function=show_installed_ram, ns='Unknown', silent_function=False) - - # Upload info - if ENABLED_UPLOAD_DATA: - print_info('Finalizing') - try_and_print(message='Compressing Info...', - function=compress_info, cs='Done') - try_and_print(message='Uploading to NAS...', - function=upload_info, cs='Done') - - # Play audio, show devices, open Windows updates, and open Activation - popen_program(['mmc', 'devmgmt.msc']) - run_hwinfo_sensors() - popen_program(['control', '/name', 'Microsoft.WindowsUpdate']) - if not windows_is_activated(): - popen_program('slui') - sleep(3) - run_xmplay() - - # Done - print_standard('\nDone.') - pause('Press Enter exit...') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: System Checklist + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.cleanup import * +from functions.diags import * +from functions.info import * +from functions.product_keys import * +from functions.setup import * +init_global_vars() +os.system('title {}: System Checklist Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\System Checklist.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: System Checklist Tool\n'.format(KIT_NAME_FULL)) + ticket_number = get_ticket_number() + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + 'BIOSKeyNotFoundError': 'BIOS key not found', + }, + 'Warning': {}} + print_info('Starting System Checklist for Ticket #{}\n'.format( + ticket_number)) + + # Configure + print_info('Configure') + if global_vars['OS']['Version'] == '10': + try_and_print(message='Explorer...', + function=config_explorer_system, cs='Done') + try_and_print(message='Updating Clock...', + function=update_clock, cs='Done') + + # Cleanup + print_info('Cleanup') + try_and_print(message='Desktop...', + function=cleanup_desktop, cs='Done') + try_and_print(message='AdwCleaner...', + function=cleanup_adwcleaner, cs='Done') + + # Export system info + print_info('Backup System Information') + try_and_print(message='AIDA64 reports...', + function=run_aida64, cs='Done') + try_and_print(message='File listing...', + function=backup_file_list, cs='Done') + try_and_print(message='Power plans...', + function=backup_power_plans, cs='Done') + try_and_print(message='Product Keys...', + function=run_produkey, cs='Done') + try_and_print(message='Registry...', + function=backup_registry, cs='Done') + + # User data + print_info('User Data') + show_user_data_summary() + + # Summary + print_info('Summary') + try_and_print(message='Operating System:', + function=show_os_name, ns='Unknown', silent_function=False) + try_and_print(message='Activation:', + function=show_os_activation, ns='Unknown', silent_function=False) + if (not windows_is_activated() + and global_vars['OS']['Version'] in ('8', '10')): + try_and_print(message='BIOS Activation:', + function=activate_windows_with_bios, + other_results=other_results) + try_and_print(message='Installed Office:', + function=get_installed_office, ns='Unknown', print_return=True) + show_free_space() + try_and_print(message='Installed RAM:', + function=show_installed_ram, ns='Unknown', silent_function=False) + + # Upload info + if ENABLED_UPLOAD_DATA: + print_info('Finalizing') + try_and_print(message='Compressing Info...', + function=compress_info, cs='Done') + try_and_print(message='Uploading to NAS...', + function=upload_info, cs='Done') + + # Play audio, show devices, open Windows updates, and open Activation + popen_program(['mmc', 'devmgmt.msc']) + run_hwinfo_sensors() + popen_program(['control', '/name', 'Microsoft.WindowsUpdate']) + if not windows_is_activated(): + popen_program('slui') + sleep(3) + run_xmplay() + + # Done + print_standard('\nDone.') + pause('Press Enter exit...') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/system_diagnostics.py b/.bin/Scripts/system_diagnostics.py index e6b9820e..62aeb85c 100644 --- a/.bin/Scripts/system_diagnostics.py +++ b/.bin/Scripts/system_diagnostics.py @@ -1,123 +1,123 @@ -# Wizard Kit: System Diagnostics - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.browsers import * -from functions.diags import * -from functions.info import * -from functions.product_keys import * -from functions.repairs import * -init_global_vars() -os.system('title {}: System Diagnostics Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\System Diagnostics.log'.format( - **global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: System Diagnostics Tool\n'.format(KIT_NAME_FULL)) - ticket_number = get_ticket_number() - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }, - 'Warning': { - 'GenericRepair': 'Repaired', - 'UnsupportedOSError': 'Unsupported OS', - }} - print_info('Starting System Diagnostics for Ticket #{}\n'.format( - ticket_number)) - - # Sanitize Environment - print_info('Sanitizing Environment') - try_and_print(message='Killing processes...', - function=run_process_killer, cs='Done') - try_and_print(message='Running RKill...', - function=run_rkill, cs='Done') - try_and_print(message='Running TDSSKiller...', - function=run_tdsskiller, cs='Done') - - # Re-run if earlier process was stopped. - stay_awake() - - # Start diags - print_info('Starting Background Scans') - check_connection() - try_and_print(message='Running HitmanPro...', - function=run_hitmanpro, cs='Started') - try_and_print(message='Running Autoruns...', - function=run_autoruns, cs='Started') - - # OS Health Checks - print_info('OS Health Checks') - try_and_print( - message='CHKDSK ({SYSTEMDRIVE})...'.format(**global_vars['Env']), - function=run_chkdsk, other_results=other_results) - try_and_print(message='SFC scan...', - function=run_sfc_scan, other_results=other_results) - try_and_print(message='DISM CheckHealth...', - function=run_dism, other_results=other_results, repair=False) - - # Scan for supported browsers - print_info('Scanning for browsers') - scan_for_browsers() - - # Export system info - print_info('Backup System Information') - try_and_print(message='AIDA64 reports...', - function=run_aida64, cs='Done') - try_and_print(message='BleachBit report...', - function=run_bleachbit, cs='Done') - backup_browsers() - try_and_print(message='File listing...', - function=backup_file_list, cs='Done') - try_and_print(message='Power plans...', - function=backup_power_plans, cs='Done') - try_and_print(message='Product Keys...', - function=run_produkey, cs='Done') - try_and_print(message='Registry...', - function=backup_registry, cs='Done') - - # Summary - print_info('Summary') - try_and_print(message='Temp Size:', - function=show_temp_files_size, silent_function=False) - show_free_space() - try_and_print(message='Installed RAM:', - function=show_installed_ram, ns='Unknown', silent_function=False) - try_and_print(message='Installed Office:', - function=get_installed_office, ns='Unknown', print_return=True) - try_and_print(message='Product Keys:', - function=get_product_keys, ns='Unknown', print_return=True) - try_and_print(message='Operating System:', - function=show_os_name, ns='Unknown', silent_function=False) - try_and_print(message='', - function=show_os_activation, ns='Unknown', silent_function=False) - - # User data - print_info('User Data') - try: - show_user_data_summary() - except Exception: - print_error(' Unknown error.') - - # Upload info - print_info('Finalizing') - try_and_print(message='Compressing Info...', - function=compress_info, cs='Done') - try_and_print(message='Uploading to NAS...', - function=upload_info, cs='Done') - - # Done - print_standard('\nDone.') - pause('Press Enter to exit...') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: System Diagnostics + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.browsers import * +from functions.diags import * +from functions.info import * +from functions.product_keys import * +from functions.repairs import * +init_global_vars() +os.system('title {}: System Diagnostics Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\System Diagnostics.log'.format( + **global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: System Diagnostics Tool\n'.format(KIT_NAME_FULL)) + ticket_number = get_ticket_number() + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }, + 'Warning': { + 'GenericRepair': 'Repaired', + 'UnsupportedOSError': 'Unsupported OS', + }} + print_info('Starting System Diagnostics for Ticket #{}\n'.format( + ticket_number)) + + # Sanitize Environment + print_info('Sanitizing Environment') + try_and_print(message='Killing processes...', + function=run_process_killer, cs='Done') + try_and_print(message='Running RKill...', + function=run_rkill, cs='Done') + try_and_print(message='Running TDSSKiller...', + function=run_tdsskiller, cs='Done') + + # Re-run if earlier process was stopped. + stay_awake() + + # Start diags + print_info('Starting Background Scans') + check_connection() + try_and_print(message='Running HitmanPro...', + function=run_hitmanpro, cs='Started') + try_and_print(message='Running Autoruns...', + function=run_autoruns, cs='Started') + + # OS Health Checks + print_info('OS Health Checks') + try_and_print( + message='CHKDSK ({SYSTEMDRIVE})...'.format(**global_vars['Env']), + function=run_chkdsk, other_results=other_results) + try_and_print(message='SFC scan...', + function=run_sfc_scan, other_results=other_results) + try_and_print(message='DISM CheckHealth...', + function=run_dism, other_results=other_results, repair=False) + + # Scan for supported browsers + print_info('Scanning for browsers') + scan_for_browsers() + + # Export system info + print_info('Backup System Information') + try_and_print(message='AIDA64 reports...', + function=run_aida64, cs='Done') + try_and_print(message='BleachBit report...', + function=run_bleachbit, cs='Done') + backup_browsers() + try_and_print(message='File listing...', + function=backup_file_list, cs='Done') + try_and_print(message='Power plans...', + function=backup_power_plans, cs='Done') + try_and_print(message='Product Keys...', + function=run_produkey, cs='Done') + try_and_print(message='Registry...', + function=backup_registry, cs='Done') + + # Summary + print_info('Summary') + try_and_print(message='Temp Size:', + function=show_temp_files_size, silent_function=False) + show_free_space() + try_and_print(message='Installed RAM:', + function=show_installed_ram, ns='Unknown', silent_function=False) + try_and_print(message='Installed Office:', + function=get_installed_office, ns='Unknown', print_return=True) + try_and_print(message='Product Keys:', + function=get_product_keys, ns='Unknown', print_return=True) + try_and_print(message='Operating System:', + function=show_os_name, ns='Unknown', silent_function=False) + try_and_print(message='', + function=show_os_activation, ns='Unknown', silent_function=False) + + # User data + print_info('User Data') + try: + show_user_data_summary() + except Exception: + print_error(' Unknown error.') + + # Upload info + print_info('Finalizing') + try_and_print(message='Compressing Info...', + function=compress_info, cs='Done') + try_and_print(message='Uploading to NAS...', + function=upload_info, cs='Done') + + # Done + print_standard('\nDone.') + pause('Press Enter to exit...') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/transferred_keys.py b/.bin/Scripts/transferred_keys.py index 8533b16e..30598857 100644 --- a/.bin/Scripts/transferred_keys.py +++ b/.bin/Scripts/transferred_keys.py @@ -1,28 +1,28 @@ -# Wizard Kit: Search for product keys in the transfer folder - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.product_keys import * -init_global_vars() -os.system('title {}: Transferred Key Finder'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\Transferred Keys.log'.format(**global_vars) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: Transferred Key Finder\n'.format(KIT_NAME_FULL)) - try_and_print(message='Searching for keys...', - function=list_clientdir_keys, print_return=True) - - # Done - print_standard('\nDone.') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Search for product keys in the transfer folder + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.product_keys import * +init_global_vars() +os.system('title {}: Transferred Key Finder'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\Transferred Keys.log'.format(**global_vars) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: Transferred Key Finder\n'.format(KIT_NAME_FULL)) + try_and_print(message='Searching for keys...', + function=list_clientdir_keys, print_return=True) + + # Done + print_standard('\nDone.') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/update_kit.py b/.bin/Scripts/update_kit.py index 9e4b09a2..c25a782a 100644 --- a/.bin/Scripts/update_kit.py +++ b/.bin/Scripts/update_kit.py @@ -1,142 +1,142 @@ -# Wizard Kit: Download the latest versions of the programs in the kit - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.update import * -init_global_vars() -os.system('title {}: Kit Update Tool'.format(KIT_NAME_FULL)) - -if __name__ == '__main__': - try: - os.system('cls') - print_info('{}: Kit Update Tool\n'.format(KIT_NAME_FULL)) - other_results = { - 'Error': { - 'CalledProcessError': 'Unknown Error', - }} - - ## Prep ## - update_sdio = ask('Update SDI Origin?') - - ## Download ## - print_success('Downloading tools') - - # Data Recovery - print_info(' Data Recovery') - try_and_print(message='TestDisk / PhotoRec...', function=update_testdisk, other_results=other_results, width=40) - - # Data Transfers - print_info(' Data Transfers') - try_and_print(message='FastCopy...', function=update_fastcopy, other_results=other_results, width=40) - try_and_print(message='wimlib...', function=update_wimlib, other_results=other_results, width=40) - try_and_print(message='XYplorer...', function=update_xyplorer, other_results=other_results, width=40) - - # Diagnostics - print_info(' Diagnostics') - try_and_print(message='AIDA64...', function=update_aida64, other_results=other_results, width=40) - try_and_print(message='Autoruns...', function=update_autoruns, other_results=other_results, width=40) - try_and_print(message='BleachBit...', function=update_bleachbit, other_results=other_results, width=40) - try_and_print(message='BlueScreenView...', function=update_bluescreenview, other_results=other_results, width=40) - try_and_print(message='ERUNT...', function=update_erunt, other_results=other_results, width=40) - try_and_print(message='HitmanPro...', function=update_hitmanpro, other_results=other_results, width=40) - try_and_print(message='HWiNFO...', function=update_hwinfo, other_results=other_results, width=40) - try_and_print(message='ProduKey...', function=update_produkey, other_results=other_results, width=40) - - # Drivers - print_info(' Drivers') - try_and_print(message='Intel RST...', function=update_intel_rst, other_results=other_results, width=40) - try_and_print(message='Intel SSD Toolbox...', function=update_intel_ssd_toolbox, other_results=other_results, width=40) - try_and_print(message='Samsing Magician...', function=update_samsung_magician, other_results=other_results, width=40) - if update_sdio: - try_and_print(message='Snappy Driver Installer Origin...', function=update_sdi_origin, other_results=other_results, width=40) - - # Installers - print_info(' Installers') - try_and_print(message='Adobe Reader DC...', function=update_adobe_reader_dc, other_results=other_results, width=40) - try_and_print(message='MS Office...', function=update_office, other_results=other_results, width=40) - try_and_print(message='Visual C++ Runtimes...', function=update_vcredists, other_results=other_results, width=40) - update_all_ninite(other_results=other_results, width=40) - - # Misc - print_info(' Misc') - try_and_print(message='Caffeine...', function=update_caffeine, other_results=other_results, width=40) - try_and_print(message='Classic Start Skin...', function=update_classic_start_skin, other_results=other_results, width=40) - try_and_print(message='Du...', function=update_du, other_results=other_results, width=40) - try_and_print(message='Everything...', function=update_everything, other_results=other_results, width=40) - try_and_print(message='PuTTY...', function=update_putty, other_results=other_results, width=40) - try_and_print(message='Notepad++...', function=update_notepadplusplus, other_results=other_results, width=40) - try_and_print(message='TreeSizeFree...', function=update_treesizefree, other_results=other_results, width=40) - try_and_print(message='XMPlay...', function=update_xmplay, other_results=other_results, width=40) - - # Repairs - print_info(' Repairs') - try_and_print(message='AdwCleaner...', function=update_adwcleaner, other_results=other_results, width=40) - try_and_print(message='KVRT...', function=update_kvrt, other_results=other_results, width=40) - try_and_print(message='RKill...', function=update_rkill, other_results=other_results, width=40) - try_and_print(message='TDSSKiller...', function=update_tdsskiller, other_results=other_results, width=40) - - # Uninstallers - print_info(' Uninstallers') - try_and_print(message='IObit Uninstaller...', function=update_iobit_uninstaller, other_results=other_results, width=40) - - ## Review ## - print_standard('Please review the results and download/extract any missing items to .cbin') - pause('Press Enter to compress the .cbin items') - - ## Compress ## - print_success('Compressing tools') - print_info(' _Drivers') - for item in os.scandir(r'{}\_Drivers'.format(global_vars['CBinDir'])): - if not re.search(r'^(_Drivers|.*7z)$', item.name, re.IGNORECASE): - try_and_print( - message='{}...'.format(item.name), - function=compress_and_remove_item, - other_results = other_results, - width=40, - item = item) - print_info(' .cbin') - for item in os.scandir(global_vars['CBinDir']): - if not re.search(r'^(_Drivers|_include|.*7z)$', item.name, re.IGNORECASE): - try_and_print( - message='{}...'.format(item.name), - function=compress_and_remove_item, - other_results = other_results, - width=40, - item = item) - - ## Search for network Office/QuickBooks installers & add to LAUNCHERS - print_success('Scanning for network installers') - scan_for_net_installers(OFFICE_SERVER, 'Office', min_year=2010) - scan_for_net_installers(QUICKBOOKS_SERVER, 'QuickBooks', min_year=2015) - - ## Generate Launchers - print_success('Generating launchers') - for section in sorted(LAUNCHERS.keys()): - print_info(' {}'.format(section)) - for name, options in sorted(LAUNCHERS[section].items()): - try_and_print(message=name, function=generate_launcher, - section=section, name=name, options=options, - other_results=other_results, width=40) - - # Rename "Copy WizardKit.cmd" (if necessary) - source = r'{}\Scripts\Copy WizardKit.cmd'.format(global_vars['BinDir']) - dest = r'{}\Copy {}.cmd'.format(global_vars['BaseDir'], KIT_NAME_FULL) - if os.path.exists(source): - try: - shutil.move(source, dest) - except Exception: - print_error(' Failed to rename "{}.cmd" to "{}.cmd"'.format( - 'Copy WizardKit', KIT_NAME_FULL)) - - # Done - print_standard('\nDone.') - pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Download the latest versions of the programs in the kit + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.update import * +init_global_vars() +os.system('title {}: Kit Update Tool'.format(KIT_NAME_FULL)) + +if __name__ == '__main__': + try: + os.system('cls') + print_info('{}: Kit Update Tool\n'.format(KIT_NAME_FULL)) + other_results = { + 'Error': { + 'CalledProcessError': 'Unknown Error', + }} + + ## Prep ## + update_sdio = ask('Update SDI Origin?') + + ## Download ## + print_success('Downloading tools') + + # Data Recovery + print_info(' Data Recovery') + try_and_print(message='TestDisk / PhotoRec...', function=update_testdisk, other_results=other_results, width=40) + + # Data Transfers + print_info(' Data Transfers') + try_and_print(message='FastCopy...', function=update_fastcopy, other_results=other_results, width=40) + try_and_print(message='wimlib...', function=update_wimlib, other_results=other_results, width=40) + try_and_print(message='XYplorer...', function=update_xyplorer, other_results=other_results, width=40) + + # Diagnostics + print_info(' Diagnostics') + try_and_print(message='AIDA64...', function=update_aida64, other_results=other_results, width=40) + try_and_print(message='Autoruns...', function=update_autoruns, other_results=other_results, width=40) + try_and_print(message='BleachBit...', function=update_bleachbit, other_results=other_results, width=40) + try_and_print(message='BlueScreenView...', function=update_bluescreenview, other_results=other_results, width=40) + try_and_print(message='ERUNT...', function=update_erunt, other_results=other_results, width=40) + try_and_print(message='HitmanPro...', function=update_hitmanpro, other_results=other_results, width=40) + try_and_print(message='HWiNFO...', function=update_hwinfo, other_results=other_results, width=40) + try_and_print(message='ProduKey...', function=update_produkey, other_results=other_results, width=40) + + # Drivers + print_info(' Drivers') + try_and_print(message='Intel RST...', function=update_intel_rst, other_results=other_results, width=40) + try_and_print(message='Intel SSD Toolbox...', function=update_intel_ssd_toolbox, other_results=other_results, width=40) + try_and_print(message='Samsing Magician...', function=update_samsung_magician, other_results=other_results, width=40) + if update_sdio: + try_and_print(message='Snappy Driver Installer Origin...', function=update_sdi_origin, other_results=other_results, width=40) + + # Installers + print_info(' Installers') + try_and_print(message='Adobe Reader DC...', function=update_adobe_reader_dc, other_results=other_results, width=40) + try_and_print(message='MS Office...', function=update_office, other_results=other_results, width=40) + try_and_print(message='Visual C++ Runtimes...', function=update_vcredists, other_results=other_results, width=40) + update_all_ninite(other_results=other_results, width=40) + + # Misc + print_info(' Misc') + try_and_print(message='Caffeine...', function=update_caffeine, other_results=other_results, width=40) + try_and_print(message='Classic Start Skin...', function=update_classic_start_skin, other_results=other_results, width=40) + try_and_print(message='Du...', function=update_du, other_results=other_results, width=40) + try_and_print(message='Everything...', function=update_everything, other_results=other_results, width=40) + try_and_print(message='PuTTY...', function=update_putty, other_results=other_results, width=40) + try_and_print(message='Notepad++...', function=update_notepadplusplus, other_results=other_results, width=40) + try_and_print(message='TreeSizeFree...', function=update_treesizefree, other_results=other_results, width=40) + try_and_print(message='XMPlay...', function=update_xmplay, other_results=other_results, width=40) + + # Repairs + print_info(' Repairs') + try_and_print(message='AdwCleaner...', function=update_adwcleaner, other_results=other_results, width=40) + try_and_print(message='KVRT...', function=update_kvrt, other_results=other_results, width=40) + try_and_print(message='RKill...', function=update_rkill, other_results=other_results, width=40) + try_and_print(message='TDSSKiller...', function=update_tdsskiller, other_results=other_results, width=40) + + # Uninstallers + print_info(' Uninstallers') + try_and_print(message='IObit Uninstaller...', function=update_iobit_uninstaller, other_results=other_results, width=40) + + ## Review ## + print_standard('Please review the results and download/extract any missing items to .cbin') + pause('Press Enter to compress the .cbin items') + + ## Compress ## + print_success('Compressing tools') + print_info(' _Drivers') + for item in os.scandir(r'{}\_Drivers'.format(global_vars['CBinDir'])): + if not re.search(r'^(_Drivers|.*7z)$', item.name, re.IGNORECASE): + try_and_print( + message='{}...'.format(item.name), + function=compress_and_remove_item, + other_results = other_results, + width=40, + item = item) + print_info(' .cbin') + for item in os.scandir(global_vars['CBinDir']): + if not re.search(r'^(_Drivers|_include|.*7z)$', item.name, re.IGNORECASE): + try_and_print( + message='{}...'.format(item.name), + function=compress_and_remove_item, + other_results = other_results, + width=40, + item = item) + + ## Search for network Office/QuickBooks installers & add to LAUNCHERS + print_success('Scanning for network installers') + scan_for_net_installers(OFFICE_SERVER, 'Office', min_year=2010) + scan_for_net_installers(QUICKBOOKS_SERVER, 'QuickBooks', min_year=2015) + + ## Generate Launchers + print_success('Generating launchers') + for section in sorted(LAUNCHERS.keys()): + print_info(' {}'.format(section)) + for name, options in sorted(LAUNCHERS[section].items()): + try_and_print(message=name, function=generate_launcher, + section=section, name=name, options=options, + other_results=other_results, width=40) + + # Rename "Copy WizardKit.cmd" (if necessary) + source = r'{}\Scripts\Copy WizardKit.cmd'.format(global_vars['BinDir']) + dest = r'{}\Copy {}.cmd'.format(global_vars['BaseDir'], KIT_NAME_FULL) + if os.path.exists(source): + try: + shutil.move(source, dest) + except Exception: + print_error(' Failed to rename "{}.cmd" to "{}.cmd"'.format( + 'Copy WizardKit', KIT_NAME_FULL)) + + # Done + print_standard('\nDone.') + pause("Press Enter to exit...") + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/user_checklist.py b/.bin/Scripts/user_checklist.py index b70c4b1d..0154a2e0 100644 --- a/.bin/Scripts/user_checklist.py +++ b/.bin/Scripts/user_checklist.py @@ -1,83 +1,83 @@ -# Wizard Kit: User Checklist - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.browsers import * -from functions.cleanup import * -from functions.setup import * -init_global_vars() -os.system('title {}: User Checklist Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\User Checklist ({USERNAME}).log'.format( - **global_vars, **global_vars['Env']) - -if __name__ == '__main__': - try: - stay_awake() - os.system('cls') - print_info('{}: User Checklist\n'.format(KIT_NAME_FULL)) - other_results = { - 'Warning': { - 'NotInstalledError': 'Not installed', - 'NoProfilesError': 'No profiles found', - }} - answer_config_browsers = ask('Install adblock?') - if answer_config_browsers: - answer_reset_browsers = ask( - 'Reset browsers to safe defaults first?') - if global_vars['OS']['Version'] == '10': - answer_config_classicshell = ask('Configure ClassicShell?') - answer_config_explorer_user = ask('Configure Explorer?') - - # Cleanup - print_info('Cleanup') - try_and_print(message='Desktop...', - function=cleanup_desktop, cs='Done') - - # Scan for supported browsers - print_info('Scanning for browsers') - scan_for_browsers() - - # Homepages - print_info('Current homepages') - list_homepages() - - # Backup - print_info('Backing up browsers') - backup_browsers() - - # Reset - if answer_config_browsers and answer_reset_browsers: - print_info('Resetting browsers') - reset_browsers() - - # Configure - print_info('Configuring programs') - if answer_config_browsers: - install_adblock() - if global_vars['OS']['Version'] == '10': - if answer_config_classicshell: - try_and_print(message='ClassicStart...', - function=config_classicstart, cs='Done') - if answer_config_explorer_user: - try_and_print(message='Explorer...', - function=config_explorer_user, cs='Done') - if (not answer_config_browsers - and not answer_config_classicshell - and not answer_config_explorer_user): - print_warning(' Skipped') - else: - if not answer_config_browsers: - print_warning(' Skipped') - - # Done - print_standard('\nDone.') - pause('Press Enter to exit...') - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: User Checklist + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.browsers import * +from functions.cleanup import * +from functions.setup import * +init_global_vars() +os.system('title {}: User Checklist Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\User Checklist ({USERNAME}).log'.format( + **global_vars, **global_vars['Env']) + +if __name__ == '__main__': + try: + stay_awake() + os.system('cls') + print_info('{}: User Checklist\n'.format(KIT_NAME_FULL)) + other_results = { + 'Warning': { + 'NotInstalledError': 'Not installed', + 'NoProfilesError': 'No profiles found', + }} + answer_config_browsers = ask('Install adblock?') + if answer_config_browsers: + answer_reset_browsers = ask( + 'Reset browsers to safe defaults first?') + if global_vars['OS']['Version'] == '10': + answer_config_classicshell = ask('Configure ClassicShell?') + answer_config_explorer_user = ask('Configure Explorer?') + + # Cleanup + print_info('Cleanup') + try_and_print(message='Desktop...', + function=cleanup_desktop, cs='Done') + + # Scan for supported browsers + print_info('Scanning for browsers') + scan_for_browsers() + + # Homepages + print_info('Current homepages') + list_homepages() + + # Backup + print_info('Backing up browsers') + backup_browsers() + + # Reset + if answer_config_browsers and answer_reset_browsers: + print_info('Resetting browsers') + reset_browsers() + + # Configure + print_info('Configuring programs') + if answer_config_browsers: + install_adblock() + if global_vars['OS']['Version'] == '10': + if answer_config_classicshell: + try_and_print(message='ClassicStart...', + function=config_classicstart, cs='Done') + if answer_config_explorer_user: + try_and_print(message='Explorer...', + function=config_explorer_user, cs='Done') + if (not answer_config_browsers + and not answer_config_classicshell + and not answer_config_explorer_user): + print_warning(' Skipped') + else: + if not answer_config_browsers: + print_warning(' Skipped') + + # Done + print_standard('\nDone.') + pause('Press Enter to exit...') + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/Scripts/user_data_transfer.py b/.bin/Scripts/user_data_transfer.py index cd6b2605..d1e4b3a0 100644 --- a/.bin/Scripts/user_data_transfer.py +++ b/.bin/Scripts/user_data_transfer.py @@ -1,53 +1,53 @@ -# Wizard Kit: Copy user data to the system from a local or network source - -import os -import sys - -# Init -os.chdir(os.path.dirname(os.path.realpath(__file__))) -sys.path.append(os.getcwd()) -from functions.data import * -from functions.repairs import * -init_global_vars() -os.system('title {}: User Data Transfer Tool'.format(KIT_NAME_FULL)) -global_vars['LogFile'] = r'{LogDir}\User Data Transfer.log'.format(**global_vars) - -if __name__ == '__main__': - try: - # Prep - stay_awake() - os.system('cls') - print_info('{}: User Data Transfer Tool\n'.format(KIT_NAME_FULL)) - ticket_number = get_ticket_number() - folder_path = r'{}\Transfer'.format(KIT_NAME_SHORT) - dest = select_destination(folder_path=folder_path, - prompt='Which disk are we transferring to?') - source = select_source(ticket_number) - items = scan_source(source, dest) - - # Transfer - os.system('cls') - print_info('Transfer Details:\n') - show_info('Ticket:', ticket_number) - show_info('Source:', source.path) - show_info('Destination:', dest) - - if (not ask('Proceed with transfer?')): - umount_backup_shares() - abort() - - print_info('Transferring Data') - transfer_source(source, dest, items) - try_and_print(message='Removing extra files...', - function=cleanup_transfer, cs='Done') - umount_backup_shares() - - # Done - run_kvrt() - print_standard('\nDone.') - pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() +# Wizard Kit: Copy user data to the system from a local or network source + +import os +import sys + +# Init +os.chdir(os.path.dirname(os.path.realpath(__file__))) +sys.path.append(os.getcwd()) +from functions.data import * +from functions.repairs import * +init_global_vars() +os.system('title {}: User Data Transfer Tool'.format(KIT_NAME_FULL)) +global_vars['LogFile'] = r'{LogDir}\User Data Transfer.log'.format(**global_vars) + +if __name__ == '__main__': + try: + # Prep + stay_awake() + os.system('cls') + print_info('{}: User Data Transfer Tool\n'.format(KIT_NAME_FULL)) + ticket_number = get_ticket_number() + folder_path = r'{}\Transfer'.format(KIT_NAME_SHORT) + dest = select_destination(folder_path=folder_path, + prompt='Which disk are we transferring to?') + source = select_source(ticket_number) + items = scan_source(source, dest) + + # Transfer + os.system('cls') + print_info('Transfer Details:\n') + show_info('Ticket:', ticket_number) + show_info('Source:', source.path) + show_info('Destination:', dest) + + if (not ask('Proceed with transfer?')): + umount_backup_shares() + abort() + + print_info('Transferring Data') + transfer_source(source, dest, items) + try_and_print(message='Removing extra files...', + function=cleanup_transfer, cs='Done') + umount_backup_shares() + + # Done + run_kvrt() + print_standard('\nDone.') + pause("Press Enter to exit...") + exit_script() + except SystemExit: + pass + except: + major_exception() diff --git a/.bin/_Drivers/SDIO/sdi.cfg b/.bin/_Drivers/SDIO/sdi.cfg index 9abde84d..614df221 100644 --- a/.bin/_Drivers/SDIO/sdi.cfg +++ b/.bin/_Drivers/SDIO/sdi.cfg @@ -1,24 +1,24 @@ -"-drp_dir:drivers" -"-index_dir:indexes\SDI" -"-output_dir:indexes\SDI\txt" -"-data_dir:tools\SDI" -"-log_dir:logs" - -"-finish_cmd:" -"-finishrb_cmd:" -"-finish_upd_cmd:" - -"-lang:English" -"-theme:YetAnotherSDI" --hintdelay:250 --license:1 --scale:256 --wndsc:3 --filters:166 - --port:50171 --downlimit:1 --uplimit:1 --connections:0 - +"-drp_dir:drivers" +"-index_dir:indexes\SDI" +"-output_dir:indexes\SDI\txt" +"-data_dir:tools\SDI" +"-log_dir:logs" + +"-finish_cmd:" +"-finishrb_cmd:" +"-finish_upd_cmd:" + +"-lang:English" +"-theme:YetAnotherSDI" +-hintdelay:250 +-license:1 +-scale:256 +-wndsc:3 +-filters:166 + +-port:50171 +-downlimit:1 +-uplimit:1 +-connections:0 + -expertmode -norestorepnt -showdrpnames2 -onlyupdates -preservecfg \ No newline at end of file diff --git a/.cbin/_include/AIDA64/full.rpf b/.cbin/_include/AIDA64/full.rpf index 73b08713..28baab65 100644 --- a/.cbin/_include/AIDA64/full.rpf +++ b/.cbin/_include/AIDA64/full.rpf @@ -1,99 +1,99 @@ -InfoPage="Computer;Summary" -InfoPage="Computer;Computer Name" -InfoPage="Computer;DMI" -InfoPage="Computer;IPMI" -InfoPage="Computer;Overclock" -InfoPage="Computer;Power Management" -InfoPage="Computer;Portable Computer" -InfoPage="Motherboard;CPU" -InfoPage="Motherboard;CPUID" -InfoPage="Motherboard;Motherboard" -InfoPage="Motherboard;Memory" -InfoPage="Motherboard;SPD" -InfoPage="Motherboard;Chipset" -InfoPage="Motherboard;BIOS" -InfoPage="Motherboard;ACPI" -InfoPage="Operating System;Operating System" -InfoPage="Operating System;Processes" -InfoPage="Operating System;System Drivers" -InfoPage="Operating System;Services" -InfoPage="Operating System;AX Files" -InfoPage="Operating System;DLL Files" -InfoPage="Operating System;Certificates" -InfoPage="Operating System;UpTime" -InfoPage="Server;Share" -InfoPage="Server;Opened Files" -InfoPage="Server;Account Security" -InfoPage="Server;Logon" -InfoPage="Server;Users" -InfoPage="Server;Local Groups" -InfoPage="Server;Global Groups" -InfoPage="Display;Windows Video" -InfoPage="Display;PCI / AGP Video" -InfoPage="Display;GPU" -InfoPage="Display;Monitor" -InfoPage="Display;Desktop" -InfoPage="Display;Multi-Monitor" -InfoPage="Display;Video Modes" -InfoPage="Display;OpenGL" -InfoPage="Display;GPGPU" -InfoPage="Display;Mantle" -InfoPage="Display;Vulkan" -InfoPage="Display;Fonts" -InfoPage="Multimedia;Windows Audio" -InfoPage="Multimedia;PCI / PnP Audio" -InfoPage="Multimedia;HD Audio" -InfoPage="Multimedia;OpenAL" -InfoPage="Multimedia;Audio Codecs" -InfoPage="Multimedia;Video Codecs" -InfoPage="Multimedia;MCI" -InfoPage="Multimedia;SAPI" -InfoPage="Storage;Windows Storage" -InfoPage="Storage;Logical Drives" -InfoPage="Storage;Physical Drives" -InfoPage="Storage;Optical Drives" -InfoPage="Storage;ASPI" -InfoPage="Storage;ATA" -InfoPage="Storage;SMART" -InfoPage="Network;Windows Network" -InfoPage="Network;PCI / PnP Network" -InfoPage="Network;RAS" -InfoPage="Network;Net Resources" -InfoPage="Network;IAM" -InfoPage="Network;Internet" -InfoPage="Network;Routes" -InfoPage="Network;IE Cookie" -InfoPage="Network;Browser History" -InfoPage="DirectX;DirectX Files" -InfoPage="DirectX;DirectX Video" -InfoPage="DirectX;DirectX Sound" -InfoPage="Devices;Windows Devices" -InfoPage="Devices;Physical Devices" -InfoPage="Devices;PCI Devices" -InfoPage="Devices;USB Devices" -InfoPage="Devices;Device Resources" -InfoPage="Devices;Input" -InfoPage="Devices;Printers" -InfoPage="Software;Auto Start" -InfoPage="Software;Scheduled" -InfoPage="Software;Installed Programs" -InfoPage="Software;Licenses" -InfoPage="Software;File Types" -InfoPage="Software;Desktop Gadgets" -InfoPage="Security;Windows Security" -InfoPage="Security;Windows Update" -InfoPage="Security;Anti-Virus" -InfoPage="Security;Firewall" -InfoPage="Security;Anti-Spyware" -InfoPage="Security;Anti-Trojan" -InfoPage="Config;Regional" -InfoPage="Config;Environment" -InfoPage="Config;Control Panel" -InfoPage="Config;Recycle Bin" -InfoPage="Config;System Files" -InfoPage="Config;System Folders" -InfoPage="Config;Event Logs" -InfoPage="Database;Database Software" -InfoPage="Database;BDE Drivers" -InfoPage="Database;ODBC Drivers" -InfoPage="Database;ODBC Data Sources" +InfoPage="Computer;Summary" +InfoPage="Computer;Computer Name" +InfoPage="Computer;DMI" +InfoPage="Computer;IPMI" +InfoPage="Computer;Overclock" +InfoPage="Computer;Power Management" +InfoPage="Computer;Portable Computer" +InfoPage="Motherboard;CPU" +InfoPage="Motherboard;CPUID" +InfoPage="Motherboard;Motherboard" +InfoPage="Motherboard;Memory" +InfoPage="Motherboard;SPD" +InfoPage="Motherboard;Chipset" +InfoPage="Motherboard;BIOS" +InfoPage="Motherboard;ACPI" +InfoPage="Operating System;Operating System" +InfoPage="Operating System;Processes" +InfoPage="Operating System;System Drivers" +InfoPage="Operating System;Services" +InfoPage="Operating System;AX Files" +InfoPage="Operating System;DLL Files" +InfoPage="Operating System;Certificates" +InfoPage="Operating System;UpTime" +InfoPage="Server;Share" +InfoPage="Server;Opened Files" +InfoPage="Server;Account Security" +InfoPage="Server;Logon" +InfoPage="Server;Users" +InfoPage="Server;Local Groups" +InfoPage="Server;Global Groups" +InfoPage="Display;Windows Video" +InfoPage="Display;PCI / AGP Video" +InfoPage="Display;GPU" +InfoPage="Display;Monitor" +InfoPage="Display;Desktop" +InfoPage="Display;Multi-Monitor" +InfoPage="Display;Video Modes" +InfoPage="Display;OpenGL" +InfoPage="Display;GPGPU" +InfoPage="Display;Mantle" +InfoPage="Display;Vulkan" +InfoPage="Display;Fonts" +InfoPage="Multimedia;Windows Audio" +InfoPage="Multimedia;PCI / PnP Audio" +InfoPage="Multimedia;HD Audio" +InfoPage="Multimedia;OpenAL" +InfoPage="Multimedia;Audio Codecs" +InfoPage="Multimedia;Video Codecs" +InfoPage="Multimedia;MCI" +InfoPage="Multimedia;SAPI" +InfoPage="Storage;Windows Storage" +InfoPage="Storage;Logical Drives" +InfoPage="Storage;Physical Drives" +InfoPage="Storage;Optical Drives" +InfoPage="Storage;ASPI" +InfoPage="Storage;ATA" +InfoPage="Storage;SMART" +InfoPage="Network;Windows Network" +InfoPage="Network;PCI / PnP Network" +InfoPage="Network;RAS" +InfoPage="Network;Net Resources" +InfoPage="Network;IAM" +InfoPage="Network;Internet" +InfoPage="Network;Routes" +InfoPage="Network;IE Cookie" +InfoPage="Network;Browser History" +InfoPage="DirectX;DirectX Files" +InfoPage="DirectX;DirectX Video" +InfoPage="DirectX;DirectX Sound" +InfoPage="Devices;Windows Devices" +InfoPage="Devices;Physical Devices" +InfoPage="Devices;PCI Devices" +InfoPage="Devices;USB Devices" +InfoPage="Devices;Device Resources" +InfoPage="Devices;Input" +InfoPage="Devices;Printers" +InfoPage="Software;Auto Start" +InfoPage="Software;Scheduled" +InfoPage="Software;Installed Programs" +InfoPage="Software;Licenses" +InfoPage="Software;File Types" +InfoPage="Software;Desktop Gadgets" +InfoPage="Security;Windows Security" +InfoPage="Security;Windows Update" +InfoPage="Security;Anti-Virus" +InfoPage="Security;Firewall" +InfoPage="Security;Anti-Spyware" +InfoPage="Security;Anti-Trojan" +InfoPage="Config;Regional" +InfoPage="Config;Environment" +InfoPage="Config;Control Panel" +InfoPage="Config;Recycle Bin" +InfoPage="Config;System Files" +InfoPage="Config;System Folders" +InfoPage="Config;Event Logs" +InfoPage="Database;Database Software" +InfoPage="Database;BDE Drivers" +InfoPage="Database;ODBC Drivers" +InfoPage="Database;ODBC Data Sources" diff --git a/.cbin/_include/AIDA64/installed_programs.rpf b/.cbin/_include/AIDA64/installed_programs.rpf index 38a51d3d..2d79cb30 100644 --- a/.cbin/_include/AIDA64/installed_programs.rpf +++ b/.cbin/_include/AIDA64/installed_programs.rpf @@ -1 +1 @@ -InfoPage="Software;Installed Programs" +InfoPage="Software;Installed Programs" diff --git a/.cbin/_include/AIDA64/licenses.rpf b/.cbin/_include/AIDA64/licenses.rpf index 06d25244..6ef298f1 100644 --- a/.cbin/_include/AIDA64/licenses.rpf +++ b/.cbin/_include/AIDA64/licenses.rpf @@ -1 +1 @@ -InfoPage="Software;Licenses" +InfoPage="Software;Licenses" diff --git a/.cbin/_include/BleachBit-Portable/BleachBit.ini b/.cbin/_include/BleachBit/BleachBit.ini similarity index 95% rename from .cbin/_include/BleachBit-Portable/BleachBit.ini rename to .cbin/_include/BleachBit/BleachBit.ini index 6a3b2c87..6c8e3992 100644 --- a/.cbin/_include/BleachBit-Portable/BleachBit.ini +++ b/.cbin/_include/BleachBit/BleachBit.ini @@ -1,77 +1,77 @@ -[Portable] - -[bleachbit] -auto_hide = False -auto_start = False -check_beta = False -check_online_updates = False -shred = False -exit_done = False -delete_confirmation = True -units_iec = True -update_winapp2 = False -first_start = True -version = 1.17 - -[hashpath] - -[list/shred_drives] - -[preserve_languages] -en = True - -[tree] -adobe_reader = True -adobe_reader.cache = True -adobe_reader.tmp = True -amule = True -amule.tmp = True -chromium = True -chromium.cache = True -firefox = True -firefox.cache = True -gimp = True -gimp.tmp = True -google_chrome = True -google_chrome.cache = True -google_earth = True -google_earth.temporary_files = True -hippo_opensim_viewer = True -hippo_opensim_viewer.cache = True -internet_explorer = True -internet_explorer.temporary_files = True -java = True -java.cache = True -libreoffice = True -libreoffice.cache = True -liferea = True -liferea.cache = True -miro = True -miro.cache = True -openofficeorg = True -openofficeorg.cache = True -opera = True -opera.cache = True -pidgin = True -pidgin.cache = True -safari = True -safari.cache = True -seamonkey = True -seamonkey.cache = True -secondlife_viewer = True -secondlife_viewer.Cache = True -system = True -system.recycle_bin = True -system.tmp = True -thunderbird = True -thunderbird.cache = True -vuze = True -vuze.cache = True -vuze.tmp = True -yahoo_messenger = True -yahoo_messenger.cache = True -winapp2_windows = True -winapp2_windows.cbs_logs = True -winapp2_windows.cbs_logs_more = True -winapp2_windows.windows_cbs_logs_more = True - +[Portable] + +[bleachbit] +auto_hide = False +auto_start = False +check_beta = False +check_online_updates = False +shred = False +exit_done = False +delete_confirmation = True +units_iec = True +update_winapp2 = False +first_start = True +version = 1.17 + +[hashpath] + +[list/shred_drives] + +[preserve_languages] +en = True + +[tree] +adobe_reader = True +adobe_reader.cache = True +adobe_reader.tmp = True +amule = True +amule.tmp = True +chromium = True +chromium.cache = True +firefox = True +firefox.cache = True +gimp = True +gimp.tmp = True +google_chrome = True +google_chrome.cache = True +google_earth = True +google_earth.temporary_files = True +hippo_opensim_viewer = True +hippo_opensim_viewer.cache = True +internet_explorer = True +internet_explorer.temporary_files = True +java = True +java.cache = True +libreoffice = True +libreoffice.cache = True +liferea = True +liferea.cache = True +miro = True +miro.cache = True +openofficeorg = True +openofficeorg.cache = True +opera = True +opera.cache = True +pidgin = True +pidgin.cache = True +safari = True +safari.cache = True +seamonkey = True +seamonkey.cache = True +secondlife_viewer = True +secondlife_viewer.Cache = True +system = True +system.recycle_bin = True +system.tmp = True +thunderbird = True +thunderbird.cache = True +vuze = True +vuze.cache = True +vuze.tmp = True +yahoo_messenger = True +yahoo_messenger.cache = True +winapp2_windows = True +winapp2_windows.cbs_logs = True +winapp2_windows.cbs_logs_more = True +winapp2_windows.windows_cbs_logs_more = True + diff --git a/.cbin/_include/NotepadPlusPlus/config.xml b/.cbin/_include/NotepadPlusPlus/config.xml index 2b14dc82..c2dd100c 100644 --- a/.cbin/_include/NotepadPlusPlus/config.xml +++ b/.cbin/_include/NotepadPlusPlus/config.xml @@ -1,56 +1,56 @@ - - - - - - standard - hide - - vertical - hide - - no - yes - no - no - yes - yes - no - yes - - - - - yes - yes - 2 - - - - - - hide - - - - - - - - - - yes - - - - - - - - - - - - - - + + + + + + standard + hide + + vertical + hide + + no + yes + no + no + yes + yes + no + yes + + + + + yes + yes + 2 + + + + + + hide + + + + + + + + + + yes + + + + + + + + + + + + + + diff --git a/.cbin/_include/XMPlay/xmplay.ini b/.cbin/_include/XMPlay/xmplay.ini index 5432bfdf..be182837 100644 --- a/.cbin/_include/XMPlay/xmplay.ini +++ b/.cbin/_include/XMPlay/xmplay.ini @@ -1,139 +1,139 @@ -[XMPlay] -MixMode=56 -AutoName=0 -WriteSource=0 -WriteSourceRes=1 -WriteSepInst=0 -WriteNoExt=0 -WriteTitle=0 -AutoAmp=1 -RGain=0 -RGainAmp=0 -RGainLimit=0 -Time=1 -ShowTenths=1 -TimeHours=1 -Volume=90 -LogVolume=1 -Balance=50 -Amplify=-1074017600 -AmpReset=1 -PanSep=50 -Loop=0 -LoopLimit=1 -LoopLimitTime=0 -DecayEnd=5 -LoopList=1 -ListTotal=0 -UnloadLast=0 -AutoAdvance=1 -ListSort=0 -FollowList=0 -AutoRemove=0 -Trim=0 -NoMute=0 -Fade=0 -NetBuffer=5 -NetPreBuffer=3 -NetTimeout=10 -RestrictRate=0 -AutoReconnect=0 -Proxy=1 -ProxyConfig= -Dither=0 -CrossFadeLen=0 -CrossFadeChange=0 -MODmode=0 -MODtimeinfo=1 -MODxfx=0 -MODloop=1 -MODloopreset=0 -MODvirtchans=256 -Mini=0 -InTray=0 -OnTop=259 -MultiInstance=0 -SaveClosePos=0 -Bubbles=3 -FadeBubbles=1 -InfoMove=0 -WindowLock=0 -PanelPos=-268374016 -ListFilenames=0 -ListQueue=0 -ListClick=1793 -AutoSave=0 -ListCols=-2146959349 -Verify=1 -NoDuplicates=0 -ScanHTML=1 -ArchiveLevel=2 -SearchDrives=0 -Random=3 -DeadStop=0 -Queue=0 -QueueStop=0 -QueuePlay=0 -QueueToggle=1 -SubDir=0 -TitleNoExt=0 -TitleSpaces=0 -TitleSubsongs=0 -TitleCUE=1 -TitleScroll=1 -TitleTray=3 -Clipboard=0 -AutoSet=0 -InfoResize=1 -InfoResizeLimit=500 -InfoTextSize=0 -InfoWidth=80 -InfoList=15 -InfoPaty=234 -InfoPatmc=20 -RestrictVis=0 -RestrictVisW=290 -RestrictVisH=218 -SpectrumSpeed=1 -VisSync=0 -VisTextSize=0 -VisRefresh=40 -HelpTextSize=0 -PanelOpen=0 -InfoPos=00020000000200005D0300003E030000 -VisSize=22010000DA000000 -FindSize=0000000000000000C8000000 -LibWidth=600 -LibSort=2 -LibMode=0 -LibCols=0000000000000000010000000000E04102000000000050410300000000005041040000000000E040050000000000E04006000000000040410700000000000000080000000000C04009000000000000000A0000000000E0400B0000000000E0400C000000000000000D000000000000000E000000000000000F00000000000000 -LibParseList=0 -LibFilePath=0 -LibAbrSize=1 -LibInlineText=1 -LibInfoTags=1 -LibKeepOverridden=1 -LibPlayTime=0 -LibAvgCount=0 -LibPlayReplace=0 -UpdateCheck=0 -UpdateTime=0 -IgnoreTypes=avi mpg mpeg -FilePath= -WritePath=X:\ -TitleForm=%?2{%2 - }%?1{%1|%0} -TitleFormList= -Find= -FindPlay=0 -FindAutoList=0 -FindIn=3 -NoCheckDead=0 -CurTrack=64 -Info=197379 -Skin=plugins\WAModern NightVision -External=464C414300666C6163202D54205449544C453D2531202D54204152544953543D2532202D5420414C42554D3D2533202D5420444154453D2534202D5420545241434B4E554D4245523D2535202D542047454E52453D2536202D5420434F4D4D454E543D2537202D6F20256F202D00666C616300404C414D45006C616D65202D2D616C742D707265736574207374616E64617264202D2D69676E6F72652D7461672D6572726F7273202D2D7474202531202D2D7461202532202D2D746C202533202D2D7479202534202D2D746E202535202D2D7467202536202D2D7463202537202D20256F006D703300864F4747454E43006F6767656E63202D74202531202D61202532202D6C202533202D64202534202D4E202535202D47202536202D6320636F6D6D656E743D2537202D6F20256F202D006F676700C800 -DSP=FF000200100000000000000040410000004100008041000100280000000000000000000000000000000000000000000000000000000000000000000000000000000000 -PluginTypes= -Shortcuts=060000004F0018020C0000004F04180250000000500019025100000050041902500000001300450251000000130445025200000027004D035300000025004B0354000000240047035600000027044D035500000025044B03810000002100490380000000220051038200000023004F03700100002D005203710100002D045203900100005A022C027B0100005100100277010000BF0435025001000026004803580100002604480351010000280050035901000028045003540100002602480354010000280250035501000041021E02560100004902170260010000460221026401000046012102610100004600210262010000460421026301000046062102740100000D001C02750100002000390276010000BF0035027E010000BF023502720100002E005303730100002E045303000200006B004E02010200006D004A02070200006F003503080200006A003702010000004D003202020000004E003102030000004E0431020A00000073013E020B00000073053E0205000000780043020101000070003B020201000071003C020301000072003D020401000073003E020501000074003F0260020000750040020801000043022E02060100006800480207010000620050022101000064004B022201000066004D022301000065004C0224010000670047022501000069004902040000007B005802 -DeviceMode=0000000080BB000002000000020000008A0200000000000003000000 -Track1=0 +[XMPlay] +MixMode=56 +AutoName=0 +WriteSource=0 +WriteSourceRes=1 +WriteSepInst=0 +WriteNoExt=0 +WriteTitle=0 +AutoAmp=1 +RGain=0 +RGainAmp=0 +RGainLimit=0 +Time=1 +ShowTenths=1 +TimeHours=1 +Volume=90 +LogVolume=1 +Balance=50 +Amplify=-1074017600 +AmpReset=1 +PanSep=50 +Loop=0 +LoopLimit=1 +LoopLimitTime=0 +DecayEnd=5 +LoopList=1 +ListTotal=0 +UnloadLast=0 +AutoAdvance=1 +ListSort=0 +FollowList=0 +AutoRemove=0 +Trim=0 +NoMute=0 +Fade=0 +NetBuffer=5 +NetPreBuffer=3 +NetTimeout=10 +RestrictRate=0 +AutoReconnect=0 +Proxy=1 +ProxyConfig= +Dither=0 +CrossFadeLen=0 +CrossFadeChange=0 +MODmode=0 +MODtimeinfo=1 +MODxfx=0 +MODloop=1 +MODloopreset=0 +MODvirtchans=256 +Mini=0 +InTray=0 +OnTop=259 +MultiInstance=0 +SaveClosePos=0 +Bubbles=3 +FadeBubbles=1 +InfoMove=0 +WindowLock=0 +PanelPos=-268374016 +ListFilenames=0 +ListQueue=0 +ListClick=1793 +AutoSave=0 +ListCols=-2146959349 +Verify=1 +NoDuplicates=0 +ScanHTML=1 +ArchiveLevel=2 +SearchDrives=0 +Random=3 +DeadStop=0 +Queue=0 +QueueStop=0 +QueuePlay=0 +QueueToggle=1 +SubDir=0 +TitleNoExt=0 +TitleSpaces=0 +TitleSubsongs=0 +TitleCUE=1 +TitleScroll=1 +TitleTray=3 +Clipboard=0 +AutoSet=0 +InfoResize=1 +InfoResizeLimit=500 +InfoTextSize=0 +InfoWidth=80 +InfoList=15 +InfoPaty=234 +InfoPatmc=20 +RestrictVis=0 +RestrictVisW=290 +RestrictVisH=218 +SpectrumSpeed=1 +VisSync=0 +VisTextSize=0 +VisRefresh=40 +HelpTextSize=0 +PanelOpen=0 +InfoPos=00020000000200005D0300003E030000 +VisSize=22010000DA000000 +FindSize=0000000000000000C8000000 +LibWidth=600 +LibSort=2 +LibMode=0 +LibCols=0000000000000000010000000000E04102000000000050410300000000005041040000000000E040050000000000E04006000000000040410700000000000000080000000000C04009000000000000000A0000000000E0400B0000000000E0400C000000000000000D000000000000000E000000000000000F00000000000000 +LibParseList=0 +LibFilePath=0 +LibAbrSize=1 +LibInlineText=1 +LibInfoTags=1 +LibKeepOverridden=1 +LibPlayTime=0 +LibAvgCount=0 +LibPlayReplace=0 +UpdateCheck=0 +UpdateTime=0 +IgnoreTypes=avi mpg mpeg +FilePath= +WritePath=X:\ +TitleForm=%?2{%2 - }%?1{%1|%0} +TitleFormList= +Find= +FindPlay=0 +FindAutoList=0 +FindIn=3 +NoCheckDead=0 +CurTrack=64 +Info=197379 +Skin=plugins\WAModern NightVision +External=464C414300666C6163202D54205449544C453D2531202D54204152544953543D2532202D5420414C42554D3D2533202D5420444154453D2534202D5420545241434B4E554D4245523D2535202D542047454E52453D2536202D5420434F4D4D454E543D2537202D6F20256F202D00666C616300404C414D45006C616D65202D2D616C742D707265736574207374616E64617264202D2D69676E6F72652D7461672D6572726F7273202D2D7474202531202D2D7461202532202D2D746C202533202D2D7479202534202D2D746E202535202D2D7467202536202D2D7463202537202D20256F006D703300864F4747454E43006F6767656E63202D74202531202D61202532202D6C202533202D64202534202D4E202535202D47202536202D6320636F6D6D656E743D2537202D6F20256F202D006F676700C800 +DSP=FF000200100000000000000040410000004100008041000100280000000000000000000000000000000000000000000000000000000000000000000000000000000000 +PluginTypes= +Shortcuts=060000004F0018020C0000004F04180250000000500019025100000050041902500000001300450251000000130445025200000027004D035300000025004B0354000000240047035600000027044D035500000025044B03810000002100490380000000220051038200000023004F03700100002D005203710100002D045203900100005A022C027B0100005100100277010000BF0435025001000026004803580100002604480351010000280050035901000028045003540100002602480354010000280250035501000041021E02560100004902170260010000460221026401000046012102610100004600210262010000460421026301000046062102740100000D001C02750100002000390276010000BF0035027E010000BF023502720100002E005303730100002E045303000200006B004E02010200006D004A02070200006F003503080200006A003702010000004D003202020000004E003102030000004E0431020A00000073013E020B00000073053E0205000000780043020101000070003B020201000071003C020301000072003D020401000073003E020501000074003F0260020000750040020801000043022E02060100006800480207010000620050022101000064004B022201000066004D022301000065004C0224010000670047022501000069004902040000007B005802 +DeviceMode=0000000080BB000002000000020000008A0200000000000003000000 +Track1=0 diff --git a/.cbin/_include/XYplorerFree/Data/XYplorer.ini b/.cbin/_include/XYplorerFree/Data/XYplorer.ini index 58a3c0893deaf5b69964ed25c9d0cf9e832094b3..a9d06a085eef76f9502c303df1cb263d0f618bdf 100644 GIT binary patch literal 40099 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 F|1X!d^ymNp literal 80190 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 K@QT)Zum1-Z_42d; diff --git a/.cbin/_include/_Office/365_32.xml b/.cbin/_include/_Office/365_32.xml index ac20b94d..093542a6 100644 --- a/.cbin/_include/_Office/365_32.xml +++ b/.cbin/_include/_Office/365_32.xml @@ -1,7 +1,7 @@ - - - - - - + + + + + + \ No newline at end of file diff --git a/.cbin/_include/_Office/365_64.xml b/.cbin/_include/_Office/365_64.xml index 1593ec31..d2b6862a 100644 --- a/.cbin/_include/_Office/365_64.xml +++ b/.cbin/_include/_Office/365_64.xml @@ -1,7 +1,7 @@ - - - - - - + + + + + + \ No newline at end of file diff --git a/.cbin/_include/_Office/hb_32.xml b/.cbin/_include/_Office/hb_32.xml index e3cc6d52..7e95c225 100644 --- a/.cbin/_include/_Office/hb_32.xml +++ b/.cbin/_include/_Office/hb_32.xml @@ -1,7 +1,7 @@ - - - - - - + + + + + + \ No newline at end of file diff --git a/.cbin/_include/_Office/hb_64.xml b/.cbin/_include/_Office/hb_64.xml index 119f7bd9..6482438b 100644 --- a/.cbin/_include/_Office/hb_64.xml +++ b/.cbin/_include/_Office/hb_64.xml @@ -1,7 +1,7 @@ - - - - - - + + + + + + \ No newline at end of file diff --git a/.cbin/_include/_Office/hs_32.xml b/.cbin/_include/_Office/hs_32.xml index bb5190ae..1d034da0 100644 --- a/.cbin/_include/_Office/hs_32.xml +++ b/.cbin/_include/_Office/hs_32.xml @@ -1,7 +1,7 @@ - - - - - - + + + + + + \ No newline at end of file diff --git a/.cbin/_include/_Office/hs_64.xml b/.cbin/_include/_Office/hs_64.xml index f5079d77..4c636636 100644 --- a/.cbin/_include/_Office/hs_64.xml +++ b/.cbin/_include/_Office/hs_64.xml @@ -1,7 +1,7 @@ - - - - - - + + + + + + \ No newline at end of file diff --git a/.cbin/_include/_vcredists/InstallAll.bat b/.cbin/_include/_vcredists/InstallAll.bat index 62211e55..597cd60e 100644 --- a/.cbin/_include/_vcredists/InstallAll.bat +++ b/.cbin/_include/_vcredists/InstallAll.bat @@ -1,22 +1,22 @@ -@echo off -setlocal - -start "" /wait "2008sp1\x32\vcredist.exe" /qb! /norestart -start "" /wait "2008sp1\x64\vcredist.exe" /qb! /norestart - -start "" /wait "2010\x32\vcredist.exe" /passive /norestart -start "" /wait "2010\x64\vcredist.exe" /passive /norestart - -start "" /wait "2012u4\x32\vcredist.exe" /passive /norestart -start "" /wait "2012u4\x64\vcredist.exe" /passive /norestart - -start "" /wait "2013\x32\vcredist.exe" /install /passive /norestart -start "" /wait "2013\x64\vcredist.exe" /install /passive /norestart - -start "" /wait "2015u3\x32\vcredist.exe" /install /passive /norestart -start "" /wait "2015u3\x64\vcredist.exe" /install /passive /norestart - -start "" /wait "2017\x32\vcredist.exe" /install /passive /norestart -start "" /wait "2017\x64\vcredist.exe" /install /passive /norestart - +@echo off +setlocal + +start "" /wait "2008sp1\x32\vcredist.exe" /qb! /norestart +start "" /wait "2008sp1\x64\vcredist.exe" /qb! /norestart + +start "" /wait "2010\x32\vcredist.exe" /passive /norestart +start "" /wait "2010\x64\vcredist.exe" /passive /norestart + +start "" /wait "2012u4\x32\vcredist.exe" /passive /norestart +start "" /wait "2012u4\x64\vcredist.exe" /passive /norestart + +start "" /wait "2013\x32\vcredist.exe" /install /passive /norestart +start "" /wait "2013\x64\vcredist.exe" /install /passive /norestart + +start "" /wait "2015u3\x32\vcredist.exe" /install /passive /norestart +start "" /wait "2015u3\x64\vcredist.exe" /install /passive /norestart + +start "" /wait "2017\x32\vcredist.exe" /install /passive /norestart +start "" /wait "2017\x64\vcredist.exe" /install /passive /norestart + endlocal \ No newline at end of file diff --git a/.root_items/Drivers/Extras/AMD.url b/.root_items/Drivers/Extras/AMD.url index 7dec6ac4..0c691d79 100644 --- a/.root_items/Drivers/Extras/AMD.url +++ b/.root_items/Drivers/Extras/AMD.url @@ -1,2 +1,2 @@ -[InternetShortcut] -URL=https://support.amd.com/en-us/download +[InternetShortcut] +URL=https://support.amd.com/en-us/download diff --git a/.root_items/Drivers/Extras/Dell (FTP - Browse for Drivers).url b/.root_items/Drivers/Extras/Dell (FTP - Browse for Drivers).url index 6ebda3cc..9c50bf4c 100644 --- a/.root_items/Drivers/Extras/Dell (FTP - Browse for Drivers).url +++ b/.root_items/Drivers/Extras/Dell (FTP - Browse for Drivers).url @@ -1,2 +1,2 @@ -[InternetShortcut] -URL=https://ftp.dell.com/browse_for_drivers/ +[InternetShortcut] +URL=https://ftp.dell.com/browse_for_drivers/ diff --git a/.root_items/Drivers/Extras/Dell (Simplified Interface).url b/.root_items/Drivers/Extras/Dell (Simplified Interface).url index 175c0448..02eed53f 100644 --- a/.root_items/Drivers/Extras/Dell (Simplified Interface).url +++ b/.root_items/Drivers/Extras/Dell (Simplified Interface).url @@ -1,2 +1,2 @@ -[InternetShortcut] -URL=https://downloads.dell.com/published/Pages/index.html +[InternetShortcut] +URL=https://downloads.dell.com/published/Pages/index.html diff --git a/.root_items/Drivers/Extras/Dell (Support Site).url b/.root_items/Drivers/Extras/Dell (Support Site).url index 25e6aa00..870d5a6c 100644 --- a/.root_items/Drivers/Extras/Dell (Support Site).url +++ b/.root_items/Drivers/Extras/Dell (Support Site).url @@ -1,6 +1,6 @@ -[InternetShortcut] -URL=http://support.dell.com/ -IDList= -HotKey=0 -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 +[InternetShortcut] +URL=http://support.dell.com/ +IDList= +HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 diff --git a/.root_items/Drivers/Extras/Device Remover.url b/.root_items/Drivers/Extras/Device Remover.url index 99675801..2da40e96 100644 --- a/.root_items/Drivers/Extras/Device Remover.url +++ b/.root_items/Drivers/Extras/Device Remover.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -IDList= -URL=http://www.majorgeeks.com/files/details/device_remover_543c.html +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +IDList= +URL=http://www.majorgeeks.com/files/details/device_remover_543c.html diff --git a/.root_items/Drivers/Extras/Display Driver Uninstaller.url b/.root_items/Drivers/Extras/Display Driver Uninstaller.url index 2a5a1b9e..9669192c 100644 --- a/.root_items/Drivers/Extras/Display Driver Uninstaller.url +++ b/.root_items/Drivers/Extras/Display Driver Uninstaller.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,11 -[InternetShortcut] -IDList= -URL=https://www.wagnardsoft.com/ +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,11 +[InternetShortcut] +IDList= +URL=https://www.wagnardsoft.com/ diff --git a/.root_items/Drivers/Extras/HP.url b/.root_items/Drivers/Extras/HP.url index f2ba81d2..02deee1e 100644 --- a/.root_items/Drivers/Extras/HP.url +++ b/.root_items/Drivers/Extras/HP.url @@ -1,2 +1,2 @@ -[InternetShortcut] -URL=http://support.hp.com/us-en/drivers +[InternetShortcut] +URL=http://support.hp.com/us-en/drivers diff --git a/.root_items/Drivers/Extras/Intel Driver & Support Assistant.url b/.root_items/Drivers/Extras/Intel Driver & Support Assistant.url index 45ec2894..1a2fa711 100644 --- a/.root_items/Drivers/Extras/Intel Driver & Support Assistant.url +++ b/.root_items/Drivers/Extras/Intel Driver & Support Assistant.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,11 -[InternetShortcut] -IDList= -URL=https://www.intel.com/content/www/us/en/support/detect.html +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,11 +[InternetShortcut] +IDList= +URL=https://www.intel.com/content/www/us/en/support/detect.html diff --git a/.root_items/Drivers/Extras/NVIDIA.url b/.root_items/Drivers/Extras/NVIDIA.url index 81ded381..1d54f978 100644 --- a/.root_items/Drivers/Extras/NVIDIA.url +++ b/.root_items/Drivers/Extras/NVIDIA.url @@ -1,2 +1,2 @@ -[InternetShortcut] -URL=https://www.nvidia.com/Download/index.aspx?lang=en-us +[InternetShortcut] +URL=https://www.nvidia.com/Download/index.aspx?lang=en-us diff --git a/.root_items/Drivers/Extras/Samsung Tools & Software.url b/.root_items/Drivers/Extras/Samsung Tools & Software.url index 93f5f9d3..4e78090b 100644 --- a/.root_items/Drivers/Extras/Samsung Tools & Software.url +++ b/.root_items/Drivers/Extras/Samsung Tools & Software.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -IDList= -URL=http://www.samsung.com/semiconductor/minisite/ssd/download/tools.html +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +IDList= +URL=http://www.samsung.com/semiconductor/minisite/ssd/download/tools.html diff --git a/.root_items/Installers/BackBlaze.url b/.root_items/Installers/BackBlaze.url index 6f2db611..117de4e4 100644 --- a/.root_items/Installers/BackBlaze.url +++ b/.root_items/Installers/BackBlaze.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,11 -[InternetShortcut] -URL=https://www.backblaze.com/gen/install_backblaze-af9duk -IDList= +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,11 +[InternetShortcut] +URL=https://www.backblaze.com/gen/install_backblaze-af9duk +IDList= diff --git a/.root_items/Misc/Fix Missing Optical Drive.reg b/.root_items/Misc/Fix Missing Optical Drive.reg index 41828295..75920302 100644 --- a/.root_items/Misc/Fix Missing Optical Drive.reg +++ b/.root_items/Misc/Fix Missing Optical Drive.reg @@ -1,6 +1,6 @@ -Windows Registry Editor Version 5.00 - -;Delete entries acording to http://support.microsoft.com/kb/314060 -[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Class\{4D36E965-E325-11CE-BFC1-08002BE10318}] -"UpperFilters"=- +Windows Registry Editor Version 5.00 + +;Delete entries acording to http://support.microsoft.com/kb/314060 +[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Class\{4D36E965-E325-11CE-BFC1-08002BE10318}] +"UpperFilters"=- "LowerFilters"=- \ No newline at end of file diff --git a/.root_items/Misc/Nirsoft Utilities - Outlook.url b/.root_items/Misc/Nirsoft Utilities - Outlook.url index 8db662fd..4c29ee45 100644 --- a/.root_items/Misc/Nirsoft Utilities - Outlook.url +++ b/.root_items/Misc/Nirsoft Utilities - Outlook.url @@ -1,6 +1,6 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -IDList= -URL=http://www.nirsoft.net/outlook_office_software.html -HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +IDList= +URL=http://www.nirsoft.net/outlook_office_software.html +HotKey=0 diff --git a/.root_items/Misc/Nirsoft Utilities - Passwords.url b/.root_items/Misc/Nirsoft Utilities - Passwords.url index 39cc3292..9a94bfcb 100644 --- a/.root_items/Misc/Nirsoft Utilities - Passwords.url +++ b/.root_items/Misc/Nirsoft Utilities - Passwords.url @@ -1,6 +1,6 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -IDList= -URL=http://www.nirsoft.net/password_recovery_tools.html -HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +IDList= +URL=http://www.nirsoft.net/password_recovery_tools.html +HotKey=0 diff --git a/.root_items/Misc/Sysinternals Suite (Live).url b/.root_items/Misc/Sysinternals Suite (Live).url index 8b217e29..8c05d050 100644 --- a/.root_items/Misc/Sysinternals Suite (Live).url +++ b/.root_items/Misc/Sysinternals Suite (Live).url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -IDList= -URL=http://live.sysinternals.com/ +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +IDList= +URL=http://live.sysinternals.com/ diff --git a/.root_items/Uninstallers/AV Removal Tools/AV Removal Tools.url b/.root_items/Uninstallers/AV Removal Tools/AV Removal Tools.url index b1415a2e..2e7c0cdd 100644 --- a/.root_items/Uninstallers/AV Removal Tools/AV Removal Tools.url +++ b/.root_items/Uninstallers/AV Removal Tools/AV Removal Tools.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://kb.eset.com/esetkb/index?page=content&id=SOLN146 -IDList= +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://kb.eset.com/esetkb/index?page=content&id=SOLN146 +IDList= diff --git a/.root_items/Uninstallers/AV Removal Tools/AVG.url b/.root_items/Uninstallers/AV Removal Tools/AVG.url index 2b7defa4..11225565 100644 --- a/.root_items/Uninstallers/AV Removal Tools/AVG.url +++ b/.root_items/Uninstallers/AV Removal Tools/AVG.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://www.avg.com/us-en/utilities -IDList= +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://www.avg.com/us-en/utilities +IDList= diff --git a/.root_items/Uninstallers/AV Removal Tools/Avast.url b/.root_items/Uninstallers/AV Removal Tools/Avast.url index 99b36e61..9b75b640 100644 --- a/.root_items/Uninstallers/AV Removal Tools/Avast.url +++ b/.root_items/Uninstallers/AV Removal Tools/Avast.url @@ -1,6 +1,6 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://files.avast.com/iavs9x/avastclear.exe -IDList= -HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://files.avast.com/iavs9x/avastclear.exe +IDList= +HotKey=0 diff --git a/.root_items/Uninstallers/AV Removal Tools/Avira.url b/.root_items/Uninstallers/AV Removal Tools/Avira.url index 32517145..7d78f29e 100644 --- a/.root_items/Uninstallers/AV Removal Tools/Avira.url +++ b/.root_items/Uninstallers/AV Removal Tools/Avira.url @@ -1,6 +1,6 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://dlpro.antivir.com/package/regcleaner/win32/en/avira_registry_cleaner_en.zip -IDList= -HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://dlpro.antivir.com/package/regcleaner/win32/en/avira_registry_cleaner_en.zip +IDList= +HotKey=0 diff --git a/.root_items/Uninstallers/AV Removal Tools/ESET.url b/.root_items/Uninstallers/AV Removal Tools/ESET.url index e3023961..a7d04ad8 100644 --- a/.root_items/Uninstallers/AV Removal Tools/ESET.url +++ b/.root_items/Uninstallers/AV Removal Tools/ESET.url @@ -1,6 +1,6 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://download.eset.com/special/ESETUninstaller.exe -IDList= -HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://download.eset.com/special/ESETUninstaller.exe +IDList= +HotKey=0 diff --git a/.root_items/Uninstallers/AV Removal Tools/Kaspersky.url b/.root_items/Uninstallers/AV Removal Tools/Kaspersky.url index 78534652..9edc0ea8 100644 --- a/.root_items/Uninstallers/AV Removal Tools/Kaspersky.url +++ b/.root_items/Uninstallers/AV Removal Tools/Kaspersky.url @@ -1,6 +1,6 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://media.kaspersky.com/utilities/ConsumerUtilities/kavremvr.exe -IDList= -HotKey=0 +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://media.kaspersky.com/utilities/ConsumerUtilities/kavremvr.exe +IDList= +HotKey=0 diff --git a/.root_items/Uninstallers/AV Removal Tools/MBAM.url b/.root_items/Uninstallers/AV Removal Tools/MBAM.url index 3b28c32e..e29e24c4 100644 --- a/.root_items/Uninstallers/AV Removal Tools/MBAM.url +++ b/.root_items/Uninstallers/AV Removal Tools/MBAM.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://www.malwarebytes.org/mbam-clean.exe -IDList= +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://www.malwarebytes.org/mbam-clean.exe +IDList= diff --git a/.root_items/Uninstallers/AV Removal Tools/McAfee.url b/.root_items/Uninstallers/AV Removal Tools/McAfee.url index 5eab565f..b18f3fba 100644 --- a/.root_items/Uninstallers/AV Removal Tools/McAfee.url +++ b/.root_items/Uninstallers/AV Removal Tools/McAfee.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,2 -[InternetShortcut] -URL=http://download.mcafee.com/products/licensed/cust_support_patches/MCPR.exe -IDList= +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,2 +[InternetShortcut] +URL=http://download.mcafee.com/products/licensed/cust_support_patches/MCPR.exe +IDList= diff --git a/.root_items/Uninstallers/AV Removal Tools/Norton.url b/.root_items/Uninstallers/AV Removal Tools/Norton.url index 7fd58d33..0eec5fff 100644 --- a/.root_items/Uninstallers/AV Removal Tools/Norton.url +++ b/.root_items/Uninstallers/AV Removal Tools/Norton.url @@ -1,5 +1,5 @@ -[{000214A0-0000-0000-C000-000000000046}] -Prop3=19,1 -[InternetShortcut] -URL=ftp://ftp.symantec.com/public/english_us_canada/removal_tools/Norton_Removal_Tool.exe -IDList= +[{000214A0-0000-0000-C000-000000000046}] +Prop3=19,1 +[InternetShortcut] +URL=ftp://ftp.symantec.com/public/english_us_canada/removal_tools/Norton_Removal_Tool.exe +IDList= diff --git a/Build Kit.cmd b/Build Kit.cmd index e97da978..36d1691a 100644 --- a/Build Kit.cmd +++ b/Build Kit.cmd @@ -1,63 +1,63 @@ -:: Wizard Kit: Build Tool Launcher :: - -@echo off - -:Init -setlocal -title Wizard Kit: Build Tool -call :CheckFlags %* - -:LaunchPrep -rem Verifies the environment before launching item -if not exist ".bin\Scripts\build_kit.ps1" (goto ErrorBuildKitMissing) - -:PrepNewKit -rem Copy base files to a new folder OUT\%KIT_NAME_FULL% -robocopy /e . OUT /xd .git .root_items OUT /xf .gitignore "Build Kit.cmd" ConEmu.png -robocopy /e .root_items OUT -copy ConEmu.png OUT\.bin\ConEmu\ -mkdir OUT\.cbin >nul 2>&1 -attrib +h OUT\.bin >nul 2>&1 -attrib +h OUT\.cbin >nul 2>&1 - -:Launch -rem Calls the Launch.cmd script using the variables defined above -set "file=OUT\.bin\Scripts\build_kit.ps1" -powershell -executionpolicy bypass -noprofile -file %file% || goto ErrorUnknown -goto Exit - -:: Functions :: -:CheckFlags -rem Loops through all arguments to check for accepted flags -set DEBUG= -for %%f in (%*) do ( - if /i "%%f" == "/DEBUG" (@echo on & set "DEBUG=/DEBUG") -) -@exit /b 0 - -:: Errors :: -:ErrorBuildKitMissing -echo. -echo ERROR: build_kit.ps1 script not found. -goto Abort - -:ErrorUnknown -echo. -echo ERROR: Encountered an unknown error. -goto Abort - -:Abort -color 4e -echo Aborted. -echo. -echo Press any key to exit... -pause>nul -color -rem Set errorlevel to 1 by calling color incorrectly -color 00 -goto Exit - -:: Cleanup and exit :: -:Exit -endlocal -exit /b %errorlevel% +:: Wizard Kit: Build Tool Launcher :: + +@echo off + +:Init +setlocal +title Wizard Kit: Build Tool +call :CheckFlags %* + +:LaunchPrep +rem Verifies the environment before launching item +if not exist ".bin\Scripts\build_kit.ps1" (goto ErrorBuildKitMissing) + +:PrepNewKit +rem Copy base files to a new folder OUT\%KIT_NAME_FULL% +robocopy /e . OUT /xd .git .root_items OUT /xf .gitignore "Build Kit.cmd" ConEmu.png +robocopy /e .root_items OUT +copy ConEmu.png OUT\.bin\ConEmu\ +mkdir OUT\.cbin >nul 2>&1 +attrib +h OUT\.bin >nul 2>&1 +attrib +h OUT\.cbin >nul 2>&1 + +:Launch +rem Calls the Launch.cmd script using the variables defined above +set "file=OUT\.bin\Scripts\build_kit.ps1" +powershell -executionpolicy bypass -noprofile -file %file% || goto ErrorUnknown +goto Exit + +:: Functions :: +:CheckFlags +rem Loops through all arguments to check for accepted flags +set DEBUG= +for %%f in (%*) do ( + if /i "%%f" == "/DEBUG" (@echo on & set "DEBUG=/DEBUG") +) +@exit /b 0 + +:: Errors :: +:ErrorBuildKitMissing +echo. +echo ERROR: build_kit.ps1 script not found. +goto Abort + +:ErrorUnknown +echo. +echo ERROR: Encountered an unknown error. +goto Abort + +:Abort +color 4e +echo Aborted. +echo. +echo Press any key to exit... +pause>nul +color +rem Set errorlevel to 1 by calling color incorrectly +color 00 +goto Exit + +:: Cleanup and exit :: +:Exit +endlocal +exit /b %errorlevel% diff --git a/LICENSE.txt b/LICENSE.txt index 7caf44d1..8e17b045 100644 --- a/LICENSE.txt +++ b/LICENSE.txt @@ -1,7 +1,7 @@ -Copyright (c) 2017 Alan Mason - -Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. - +Copyright (c) 2017 Alan Mason + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/README.md b/README.md index c139e1a0..00b0adce 100644 --- a/README.md +++ b/README.md @@ -1,31 +1,31 @@ -# Wizard Kit # - -A collection of scripts to help technicians service Windows systems. - -## Layout ## - -* Root - * Main script launchers: -* `.bin` - * Extracted programs: As compressed tools are run they will be extracted here. - * `Scripts` - * "Real" scripts live here and are run via their respective launchers. -* `.cbin` - * This folder holds the compressed and encrypted tool archives. They are extracted at runtime as needed. -* `Data Recovery` - * This folder is not copied by `Copy WizardKit.cmd` to help discourage recovering data to the same drive. -* `Data Transfers` -* `Diagnostics` -* `Drivers` -* `Installers` -* `Misc` -* `Repairs` -* `Uninstallers` - -## Initial Setup ## - -* Replace ConEmu.png if desired -* Run `Build Kit.cmd` which will do the following: - * Download 7-Zip, ConEmu, Notepad++, and Python (including wheel packages) - * Open `.bin\Scripts\settings\main.py` in Notepad++ for configuration +# Wizard Kit # + +A collection of scripts to help technicians service Windows systems. + +## Layout ## + +* Root + * Main script launchers: +* `.bin` + * Extracted programs: As compressed tools are run they will be extracted here. + * `Scripts` + * "Real" scripts live here and are run via their respective launchers. +* `.cbin` + * This folder holds the compressed and encrypted tool archives. They are extracted at runtime as needed. +* `Data Recovery` + * This folder is not copied by `Copy WizardKit.cmd` to help discourage recovering data to the same drive. +* `Data Transfers` +* `Diagnostics` +* `Drivers` +* `Installers` +* `Misc` +* `Repairs` +* `Uninstallers` + +## Initial Setup ## + +* Replace ConEmu.png if desired +* Run `Build Kit.cmd` which will do the following: + * Download 7-Zip, ConEmu, Notepad++, and Python (including wheel packages) + * Open `.bin\Scripts\settings\main.py` in Notepad++ for configuration * Update the rest of the tools with the `.bin\Scripts\update_kit.py` script \ No newline at end of file