## MAJOR refactoring done ##
* All .cmd Command scripts
* Brandind / Settings variables now set via .bin/Scripts/settings/main.py
* Window titles now set using KIT_FULL_NAME
* All .py Python scripts
* All ClientDir paths should now use KIT_SHORT_NAME
* Long lines wrapped to better follow PEP8
* String formatting now more consistant
* Updated run_program() and popen_program() calls to use lists
* (e.g. cmd = ['', '', '']; run_program(cmd))
** Should improve clarity IMO
* Update window titles AFTER init_global_vars() so KIT_FULL_NAME can be used
* Branding / Settings
* Support tech now configurable
* (e.g. "Please let {tech} know and they'll look into it")
* Timezone now configurable
* Upload info can now be disabled/enabled in .bin/Scripts/settings/main.py
* CHKDSK
* Combined read-only and fix scripts and added menu
* DISM
* Combined ScanHealth and RestoreHealth scripts and added menu
* functions/common.py
* BREAKING: run_program() and popen_program() no longer accept 'args' variable
* Misc
* Removed Win7 NVMe launcher
* Never used and Win7 is deprecated
* Removed "DeviceRemover" and "Display Driver Uninstaller" launchers
* Both cut too deep and were not useful
* Removed Nirsoft utilities and Sysinternals Suite launchers
* Too many tools unused.
* Added .url links to the websites in case the tools are needed
* Replaced WinDirStat with TreeSizeFree
* Replaced Q-Dir launcher with XYplorer launcher
* Q-Dir was running into issues on Windows 10
* Removed C.IntRep, ESET, and MBAM launchers from "OSR & VR"
* Removed JRT
* Deprecated and discontinued by MBAM
* Removed unsupported QuickBooks launchers (2014 and older)
* Removed unsupported Office launchers (2010 and 2013\365)
* Removed "Revo Uninstaller" launcher
* Removed infrequently used tools from "Diagnostics"
* Auslogics DiskDefrag
* BatteryInfoView
* BIOSCodes
* GpuTest
* HeavyLoad
* Bugfixes
* major_exception() try-blocks should catch CTL+c again
* Allows for manual script bailing
114 lines
3.9 KiB
Python
114 lines
3.9 KiB
Python
# 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.")
|