From a22e6f552f5c3b31db5f5969889e5d63dfa3a68c Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 19:01:03 -0700 Subject: [PATCH 01/75] Start build-ufd rewrite in python --- .bin/Scripts/{build-ufd => build-ufd.bash} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename .bin/Scripts/{build-ufd => build-ufd.bash} (100%) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd.bash similarity index 100% rename from .bin/Scripts/build-ufd rename to .bin/Scripts/build-ufd.bash From 639a338cca8101afad48d51e057a2a15090b1da8 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 19:03:56 -0700 Subject: [PATCH 02/75] Initial Python layout * Going to use docopt for argument handling * Script will be run as user using sudo where needed * Tentatively dropping tmux usage --- .bin/Scripts/build-ufd | 89 ++++++++++++++++++++++++++++++++ .bin/Scripts/functions/common.py | 51 +++++++++--------- .linux_items/packages/live_add | 1 + 3 files changed, 114 insertions(+), 27 deletions(-) create mode 100755 .bin/Scripts/build-ufd diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd new file mode 100755 index 00000000..d73b306c --- /dev/null +++ b/.bin/Scripts/build-ufd @@ -0,0 +1,89 @@ +#!/bin/env python3 +# +## Wizard Kit: UFD build tool + +# Init +import os +import sys + +sys.path.append(os.path.dirname(os.path.realpath(__file__))) + +from docopt import docopt +from functions.common import * + +set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars['Env'])) + + +# STATIC VARIABLES +DOCSTRING = '''Build UFD. + +Usage: + build-ufd [options] --ufd-device PATH --linux-iso PATH + [--linux-minimal-iso PATH] + [--main-kit PATH] + [--winpe-iso PATH] + [--extra-dir PATH] + build-ufd (-h | --help) + +Options: + -e PATH, --extra-dir PATH + -k PATH, --main-kit PATH + -l PATH, --linux-iso PATH + -m PATH, --linux-minimal-iso PATH + -u PATH, --ufd-device PATH + -w PATH, --winpe-iso PATH + + -d --debug Enable debug mode + -h --help Show this page + -v --verbose Enable verbose mode + -M --use-mbr Use real MBR instead of GPT w/ Protective MBR + -F --force Bypass all confirmation messages. USE WITH EXTREME CAUTION! + -U --update Don't format device, just update +''' +ISO_LABEL = '{}_LINUX'.format(KIT_NAME_SHORT) +UFD_LABEL = '{}_UFD'.format(KIT_NAME_SHORT) + + +# Functions +def get_full_path(item): + """Get full path to item, returns str.""" + #TODO + pass + + +def is_block_device(item): + """Verify item is a block device, returns bool.""" + #TODO + pass + + +def is_valid_main_kit(path): + """Verify path contains the main kit, returns bool.""" + + +# Main section +if __name__ == '__main__': + args = docopt(DOCSTRING) + + # Verify selections + + # Show selections + + # Double-check if formating device + + # Format and partition device + + # Mount sources + + # Copy sources + + # Update boot entries + + # Install syslinux + + # Hide items + + # Unmount sources + + +# vim: sts=2 sw=2 ts=2 diff --git a/.bin/Scripts/functions/common.py b/.bin/Scripts/functions/common.py index 502c985b..bbc2529c 100644 --- a/.bin/Scripts/functions/common.py +++ b/.bin/Scripts/functions/common.py @@ -879,25 +879,19 @@ def make_tmp_dirs(): 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['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'.format( - **global_vars) - global_vars['LogDir'] = r'{ClientDir}\Logs\{Date}'.format( - **global_vars) - global_vars['QuarantineDir'] = r'{ClientDir}\Quarantine'.format( - **global_vars) - global_vars['TmpDir'] = r'{BinDir}\tmp'.format( - **global_vars) + 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'.format(**global_vars) + global_vars['LogDir'] = r'{ClientDir}\Logs\{Date}'.format(**global_vars) + global_vars['QuarantineDir'] = r'{ClientDir}\Quarantine'.format(**global_vars) + global_vars['TmpDir'] = r'{BinDir}\tmp'.format(**global_vars) def set_linux_vars(): @@ -905,12 +899,12 @@ def set_linux_vars(): These assume we're running under a WK-Linux build.""" result = run_program(['mktemp', '-d']) - global_vars['TmpDir'] = result.stdout.decode().strip() - 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['BinDir'] = '/usr/local/bin' - global_vars['LogDir'] = global_vars['TmpDir'] + global_vars['TmpDir'] = result.stdout.decode().strip() + 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['BinDir'] = '/usr/local/bin' + global_vars['LogDir'] = '{}/Logs',format(global_vars['Env']['HOME']) global_vars['Tools'] = { 'wimlib-imagex': 'wimlib-imagex', 'SevenZip': '7z', @@ -919,10 +913,13 @@ def set_linux_vars(): def set_log_file(log_name): """Sets global var LogFile and creates path as needed.""" - folder_path = '{}{}{}'.format( - global_vars['LogDir'], - os.sep, - KIT_NAME_FULL) + if psutil.LINUX: + folder_path = global_vars['LogDir'] + else: + folder_path = '{}{}{}'.format( + global_vars['LogDir'], + os.sep, + KIT_NAME_FULL) log_file = '{}{}{}'.format( folder_path, os.sep, diff --git a/.linux_items/packages/live_add b/.linux_items/packages/live_add index 668c10c0..57f77bc1 100644 --- a/.linux_items/packages/live_add +++ b/.linux_items/packages/live_add @@ -31,6 +31,7 @@ networkmanager p7zip progsreiserfs python +python-docopt python-psutil python-requests reiserfsprogs From 575126eaa2ce91e1f1f34750258b92ea851e7216 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 20:51:54 -0700 Subject: [PATCH 03/75] Split build-ufd file to match other scripts --- .bin/Scripts/build-ufd | 109 +++++++++++++++------------------- .bin/Scripts/functions/ufd.py | 27 +++++++++ .bin/Scripts/settings/ufd.py | 80 +++++++++++++++++++++++++ 3 files changed, 154 insertions(+), 62 deletions(-) create mode 100644 .bin/Scripts/functions/ufd.py create mode 100644 .bin/Scripts/settings/ufd.py diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index d73b306c..b7324dd1 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -2,88 +2,73 @@ # ## Wizard Kit: UFD build tool -# Init import os import sys +# Init sys.path.append(os.path.dirname(os.path.realpath(__file__))) - from docopt import docopt -from functions.common import * - +from functions.ufd import * +from settings.ufd import * +init_global_vars() set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars['Env'])) -# STATIC VARIABLES -DOCSTRING = '''Build UFD. - -Usage: - build-ufd [options] --ufd-device PATH --linux-iso PATH - [--linux-minimal-iso PATH] - [--main-kit PATH] - [--winpe-iso PATH] - [--extra-dir PATH] - build-ufd (-h | --help) - -Options: - -e PATH, --extra-dir PATH - -k PATH, --main-kit PATH - -l PATH, --linux-iso PATH - -m PATH, --linux-minimal-iso PATH - -u PATH, --ufd-device PATH - -w PATH, --winpe-iso PATH - - -d --debug Enable debug mode - -h --help Show this page - -v --verbose Enable verbose mode - -M --use-mbr Use real MBR instead of GPT w/ Protective MBR - -F --force Bypass all confirmation messages. USE WITH EXTREME CAUTION! - -U --update Don't format device, just update -''' -ISO_LABEL = '{}_LINUX'.format(KIT_NAME_SHORT) -UFD_LABEL = '{}_UFD'.format(KIT_NAME_SHORT) - - -# Functions -def get_full_path(item): - """Get full path to item, returns str.""" - #TODO - pass - - -def is_block_device(item): - """Verify item is a block device, returns bool.""" - #TODO - pass - - -def is_valid_main_kit(path): - """Verify path contains the main kit, returns bool.""" - - # Main section if __name__ == '__main__': - args = docopt(DOCSTRING) + try: + args = docopt(DOCSTRING) + sources = () - # Verify selections + # Verify selections + ## UFD + try: + ufd_dev = get_full_path(args['--ufd-device']) + if not is_block_device(ufd_dev): + print_error('Invalid UFD device: {}'.format(ufd_dev)) + abort() + except Exception: + # TODO Catch FileNotFound exception and abort accordingly + raise + ## Sources + for label, source in UFD_SOURCES: + if args[source]: + try: + sources.append((label, get_full_path(source))) + except Exception: + # TODO Catch FileNotFound exception and abort accordingly + raise - # Show selections + # Show selections + # TODO FIXME + print_standard('UFD: {}'.format(ufd_dev)) + print_standard('Sources:') + for s in sources: + print_standard(' {}: {}'.format(*s)) - # Double-check if formating device + # Double-check if formating device - # Format and partition device + # Format and partition device - # Mount sources + # Copy sources - # Copy sources + # Update boot entries - # Update boot entries + # Install syslinux - # Install syslinux + # Hide items - # Hide items + # Unmount sources - # Unmount sources + # Done + if not args['--force']: + print_standard('\nDone.') + pause('Press Enter to exit...') + exit_script() + except SystemExit: + pass + except: + major_exception() # vim: sts=2 sw=2 ts=2 diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py new file mode 100644 index 00000000..654f1f27 --- /dev/null +++ b/.bin/Scripts/functions/ufd.py @@ -0,0 +1,27 @@ +# Wizard Kit: Functions - UFD + +from functions.common import * + + +def get_full_path(item): + """Get full path to item, returns str.""" + #TODO + pass + + +def is_block_device(item): + """Verify item is a block device, returns bool.""" + #TODO + pass + + +def is_valid_main_kit(path): + """Verify path contains the main kit, returns bool.""" + #TODO + pass + + +if __name__ == '__main__': + print("This file is not meant to be called directly.") + +# vim: sts=2 sw=2 ts=2 diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py new file mode 100644 index 00000000..b7f552eb --- /dev/null +++ b/.bin/Scripts/settings/ufd.py @@ -0,0 +1,80 @@ +# Wizard Kit: Settings - UFD + +from settings.main import * + +# General +DOCSTRING = '''WizardKit: Build UFD + +Usage: + build-ufd [options] --ufd-device PATH --linux-iso PATH + [--linux-minimal-iso PATH] + [--main-kit PATH] + [--winpe-iso PATH] + [--extra-dir PATH] + build-ufd (-h | --help) + +Options: + -e PATH, --extra-dir PATH + -k PATH, --main-kit PATH + -l PATH, --linux-iso PATH + -m PATH, --linux-minimal-iso PATH + -u PATH, --ufd-device PATH + -w PATH, --winpe-iso PATH + + -d --debug Enable debug mode + -h --help Show this page + -v --verbose Enable verbose mode + -M --use-mbr Use real MBR instead of GPT w/ Protective MBR + -F --force Bypass all confirmation messages. USE WITH EXTREME CAUTION! + -U --update Don't format device, just update +''' +ISO_LABEL = '{}_LINUX'.format(KIT_NAME_SHORT) +UFD_LABEL = '{}_UFD'.format(KIT_NAME_SHORT) +UFD_SOURCES = ( + # NOTE: Using tuple of tuples to ensure copy order + ('Linux', '--linux-iso'), + ('Linux (Minimal)', '--linux-minimal-iso'), + ('WinPE', '--winpe-iso'), + ('Main Kit', '--main-kit'), + ('Extras', '--extra-dir'), + ) + +# Definitions: Boot entries +## NOTE: if key path exists uncomment #value# lines +BOOT_ENTRIES = { + 'arch_minimal': 'MINIMAL', + 'sources/boot.wim': 'WINPE', + } + +# Definitions: Sources and Destinations +## NOTES: Paths are relative to the root of the ISO/UFD +## Sources use rsync's trailing slash syntax +ITEMS_LINUX_FULL = ( + ('/arch', '/'), + ('/isolinux', '/'), + ('/EFI/boot', '/EFI/'), + ('/EFI/memtest86', '/EFI/'), + ) +ITEMS_LINUX_MINIMAL = ( + ('/arch/boot/archiso.img', '/arch_minimal/'), + ('/arch/boot/vmlinuz', '/arch_minimal/'), + ('/arch/pkglist.x86_64.txt', '/arch_minimal/'), + ('/arch/x86_64', '/arch_minimal/'), + ) +ITEMS_WINPE = ( + ('/bootmgr', '/'), + ('/bootmgr.efi', '/'), + ('/en_us', '/'), + ('/Boot/', '/boot/'), + ('/EFI/Boot/', '/EFI/Microsoft/'), + ('/EFI/Microsoft/', '/EFI/Microsoft/'), + ('/Boot/BCD', '/sources/'), + ('/Boot/boot.sdi', '/sources/'), + ('/bootmgr', '/sources/'), + ('/sources/boot.wim', '/sources/'), + ) + +if __name__ == '__main__': + print("This file is not meant to be called directly.") + +# vim: sts=2 sw=2 ts=2 From c4d00a2073cc2580715c6bf0c8c4b562ea3cca06 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 22:35:09 -0700 Subject: [PATCH 04/75] Fix typos --- .bin/Scripts/build-ufd | 2 +- .bin/Scripts/functions/common.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index b7324dd1..a5577907 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -11,7 +11,7 @@ from docopt import docopt from functions.ufd import * from settings.ufd import * init_global_vars() -set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars['Env'])) +set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) # Main section diff --git a/.bin/Scripts/functions/common.py b/.bin/Scripts/functions/common.py index bbc2529c..b6008d27 100644 --- a/.bin/Scripts/functions/common.py +++ b/.bin/Scripts/functions/common.py @@ -904,7 +904,7 @@ def set_linux_vars(): global_vars['Date-Time'] = time.strftime("%Y-%m-%d_%H%M_%z") global_vars['Env'] = os.environ.copy() global_vars['BinDir'] = '/usr/local/bin' - global_vars['LogDir'] = '{}/Logs',format(global_vars['Env']['HOME']) + global_vars['LogDir'] = '{}/Logs'.format(global_vars['Env']['HOME']) global_vars['Tools'] = { 'wimlib-imagex': 'wimlib-imagex', 'SevenZip': '7z', From cd0a9456cb20cb862140409d49f72c3dbdde59ee Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 22:41:41 -0700 Subject: [PATCH 05/75] Use pathlib.Path to resolve paths * is_block_device() is no longer needed * (pathlib.Path provides that functionality) --- .bin/Scripts/functions/ufd.py | 23 ++++++++++------------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 654f1f27..441b4770 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -1,24 +1,21 @@ # Wizard Kit: Functions - UFD +import pathlib from functions.common import * def get_full_path(item): - """Get full path to item, returns str.""" - #TODO - pass + """Get full path to item, returns pathlib.Path obj.""" + path_obj = pathlib.Path(item).resolve() + if not path_obj.exists(): + raise FileNotFoundError(path_obj) + + return path_obj -def is_block_device(item): - """Verify item is a block device, returns bool.""" - #TODO - pass - - -def is_valid_main_kit(path): - """Verify path contains the main kit, returns bool.""" - #TODO - pass +def is_valid_main_kit(path_obj): + """Verify PathObj contains the main kit, returns bool.""" + return path_obj.is_dir() and path_obj.joinpath('.bin').exists() if __name__ == '__main__': From b6c6fc9aa9f9c8e0aa503cc7b06792dfb5de8bc0 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 22:44:15 -0700 Subject: [PATCH 06/75] Find paths case-insensitively --- .bin/Scripts/functions/ufd.py | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 441b4770..9aeb1b3d 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -4,6 +4,33 @@ import pathlib from functions.common import * +def case_insensitive_search(path, item): + """Search path for item case insensitively, returns str.""" + if os.path.exists('{}/{}'.format(path, item)): + # Easy mode + return '{}/{}'.format(path, item) + + # Check all items in dir + for entry in os.scandir(path): + if re.match(entry.name, item, re.IGNORECASE): + return '{}/{}'.format(path, entry.name) + + # If we get here the item wasn't found + raise FileNotFoundError('{}/{}'.format(path, item)) + + +def find_source_item(source_dir, item): + """Find item relative to source dir, returns str.""" + path = source_dir + if item.startswith('/'): + item = item[1:] + + for part in item.split('/'): + path = case_insensitive_search(path, part) + + return path + + def get_full_path(item): """Get full path to item, returns pathlib.Path obj.""" path_obj = pathlib.Path(item).resolve() From 50cb765108c5cb84bd22c63a314564b24d3e9dce Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 23:26:22 -0700 Subject: [PATCH 07/75] Merged find_source_item() and get_full_path() * Also fixed regex match (it wasn't matching the whole string) --- .bin/Scripts/functions/ufd.py | 49 +++++++++++++++++++++-------------- 1 file changed, 30 insertions(+), 19 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 9aeb1b3d..e6a13c47 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -6,37 +6,48 @@ from functions.common import * def case_insensitive_search(path, item): """Search path for item case insensitively, returns str.""" + regex_match = '^{}$'.format(item) + real_path = '' + + # Quick check first if os.path.exists('{}/{}'.format(path, item)): - # Easy mode - return '{}/{}'.format(path, item) + real_path = '{}{}{}'.format( + path, + '' if path == '/' else '/', + item, + ) # Check all items in dir for entry in os.scandir(path): - if re.match(entry.name, item, re.IGNORECASE): - return '{}/{}'.format(path, entry.name) + if re.match(regex_match, entry.name, re.IGNORECASE): + real_path = '{}{}{}'.format( + path, + '' if path == '/' else '/', + entry.name, + ) - # If we get here the item wasn't found - raise FileNotFoundError('{}/{}'.format(path, item)) + # Done + if real_path: + return real_path + else: + raise FileNotFoundError('{}/{}'.format(path, item)) -def find_source_item(source_dir, item): - """Find item relative to source dir, returns str.""" - path = source_dir - if item.startswith('/'): - item = item[1:] +def find_path(path): + """Find path case-insensitively, returns pathlib.Path obj.""" + parts = pathlib.Path(path).resolve().relative_to('/').parts + real_path = '/' - for part in item.split('/'): - path = case_insensitive_search(path, part) + # Fix case + for part in parts: + real_path = case_insensitive_search(real_path, part) - return path - - -def get_full_path(item): - """Get full path to item, returns pathlib.Path obj.""" - path_obj = pathlib.Path(item).resolve() + # Raise error if path doesn't exist + path_obj = pathlib.Path(real_path) if not path_obj.exists(): raise FileNotFoundError(path_obj) + # Done return path_obj From e420074c833f39c3157a7804a8d0d3bc97a2f8e9 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 23:35:00 -0700 Subject: [PATCH 08/75] Use correct errors in find_path() * FileNotFoundError is accurate since we're just looking for a path --- .bin/Scripts/functions/ufd.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index e6a13c47..83dd1852 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -40,7 +40,11 @@ def find_path(path): # Fix case for part in parts: - real_path = case_insensitive_search(real_path, part) + try: + real_path = case_insensitive_search(real_path, part) + except NotADirectoryError: + # Reclassify error + raise FileNotFoundError(path) # Raise error if path doesn't exist path_obj = pathlib.Path(real_path) From b166172d10faabff877f72094edc7be5746423a1 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 7 Apr 2019 23:45:08 -0700 Subject: [PATCH 09/75] Only perform case-insensitive search if needed --- .bin/Scripts/functions/ufd.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 83dd1852..f0ce6ad3 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -35,10 +35,15 @@ def case_insensitive_search(path, item): def find_path(path): """Find path case-insensitively, returns pathlib.Path obj.""" - parts = pathlib.Path(path).resolve().relative_to('/').parts - real_path = '/' + path_obj = pathlib.Path(path).resolve() + + # Quick check first + if path_obj.exists(): + return path_obj # Fix case + parts = path_obj.relative_to('/').parts + real_path = '/' for part in parts: try: real_path = case_insensitive_search(real_path, part) From 4c33c110b758d7fbb9b9ef0c58e8d1a7d6a37d7e Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 00:35:53 -0700 Subject: [PATCH 10/75] Fixed source validation --- .bin/Scripts/build-ufd | 39 +++++++++++++++++++++-------------- .bin/Scripts/functions/ufd.py | 16 +++++++++++--- .bin/Scripts/settings/ufd.py | 28 ++++++++++++------------- 3 files changed, 50 insertions(+), 33 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index a5577907..9c048dea 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -7,6 +7,7 @@ import sys # Init sys.path.append(os.path.dirname(os.path.realpath(__file__))) +from collections import OrderedDict from docopt import docopt from functions.ufd import * from settings.ufd import * @@ -18,33 +19,39 @@ set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) if __name__ == '__main__': try: args = docopt(DOCSTRING) - sources = () + sources = OrderedDict() # Verify selections ## UFD try: - ufd_dev = get_full_path(args['--ufd-device']) - if not is_block_device(ufd_dev): - print_error('Invalid UFD device: {}'.format(ufd_dev)) - abort() - except Exception: - # TODO Catch FileNotFound exception and abort accordingly - raise + ufd_dev = find_path(args['--ufd-device']) + except FileNotFoundError: + print_error('ERROR: UFD device not found: {}'.format( + args['--ufd-device'])) + abort() + if not is_valid_path(ufd_dev, 'UFD'): + print_error('ERROR: Invalid UFD device: {}'.format(ufd_dev)) + abort() ## Sources - for label, source in UFD_SOURCES: - if args[source]: + for label, data in UFD_SOURCES.items(): + s_path = args[data['Arg']] + if s_path: try: - sources.append((label, get_full_path(source))) - except Exception: - # TODO Catch FileNotFound exception and abort accordingly - raise + s_path_obj = find_path(s_path) + except FileNotFoundError: + print_error('ERROR: {} not found: {}'.format(label, s_path)) + abort() + if not is_valid_path(s_path_obj, data['Type']): + print_error('ERROR: Invalid {} source: {}'.format(label, s_path)) + abort() + sources[label] = s_path_obj # Show selections # TODO FIXME print_standard('UFD: {}'.format(ufd_dev)) print_standard('Sources:') - for s in sources: - print_standard(' {}: {}'.format(*s)) + for label, s_path in sources.items(): + print_standard(' {:<16} {}'.format(label+':', s_path)) # Double-check if formating device diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index f0ce6ad3..ae1bc37d 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -60,9 +60,19 @@ def find_path(path): return path_obj -def is_valid_main_kit(path_obj): - """Verify PathObj contains the main kit, returns bool.""" - return path_obj.is_dir() and path_obj.joinpath('.bin').exists() +def is_valid_path(path_obj, path_type): + """Verify path_obj is valid by type, returns bool.""" + valid_path = False + if path_type == 'DIR': + valid_path = path_obj.is_dir() + elif path_type == 'KIT': + valid_path = path_obj.is_dir() and path_obj.joinpath('.bin').exists() + elif path_type == 'ISO': + valid_path = path_obj.is_file() and path_obj.suffix.lower() == '.iso' + elif path_type == 'UFD': + valid_path = path_obj.is_block_device() + + return valid_path if __name__ == '__main__': diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index b7f552eb..50fc6934 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -1,25 +1,26 @@ # Wizard Kit: Settings - UFD +from collections import OrderedDict from settings.main import * # General DOCSTRING = '''WizardKit: Build UFD Usage: - build-ufd [options] --ufd-device PATH --linux-iso PATH - [--linux-minimal-iso PATH] + build-ufd [options] --ufd-device PATH --linux PATH + [--linux-minimal PATH] [--main-kit PATH] - [--winpe-iso PATH] + [--winpe PATH] [--extra-dir PATH] build-ufd (-h | --help) Options: -e PATH, --extra-dir PATH -k PATH, --main-kit PATH - -l PATH, --linux-iso PATH - -m PATH, --linux-minimal-iso PATH + -l PATH, --linux PATH + -m PATH, --linux-minimal PATH -u PATH, --ufd-device PATH - -w PATH, --winpe-iso PATH + -w PATH, --winpe PATH -d --debug Enable debug mode -h --help Show this page @@ -30,14 +31,13 @@ Options: ''' ISO_LABEL = '{}_LINUX'.format(KIT_NAME_SHORT) UFD_LABEL = '{}_UFD'.format(KIT_NAME_SHORT) -UFD_SOURCES = ( - # NOTE: Using tuple of tuples to ensure copy order - ('Linux', '--linux-iso'), - ('Linux (Minimal)', '--linux-minimal-iso'), - ('WinPE', '--winpe-iso'), - ('Main Kit', '--main-kit'), - ('Extras', '--extra-dir'), - ) +UFD_SOURCES = ({ + 'Linux': {'Arg': '--linux', 'Type': 'ISO'}, + 'Linux (Minimal)': {'Arg': '--linux-minimal', 'Type': 'ISO'}, + 'WinPE': {'Arg': '--winpe', 'Type': 'ISO'}, + 'Main Kit': {'Arg': '--main-kit', 'Type': 'KIT'}, + 'Extra Dir': {'Arg': '--extra-dir', 'Type': 'DIR'}, + }) # Definitions: Boot entries ## NOTE: if key path exists uncomment #value# lines From 5fe37b62b288bda89c7084f9fa3f4d85fea15bc6 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 02:58:07 -0700 Subject: [PATCH 11/75] Adjusted source/dest items --- .bin/Scripts/settings/ufd.py | 56 ++++++++++++++++++++---------------- 1 file changed, 32 insertions(+), 24 deletions(-) diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index 50fc6934..4f99018c 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -49,30 +49,38 @@ BOOT_ENTRIES = { # Definitions: Sources and Destinations ## NOTES: Paths are relative to the root of the ISO/UFD ## Sources use rsync's trailing slash syntax -ITEMS_LINUX_FULL = ( - ('/arch', '/'), - ('/isolinux', '/'), - ('/EFI/boot', '/EFI/'), - ('/EFI/memtest86', '/EFI/'), - ) -ITEMS_LINUX_MINIMAL = ( - ('/arch/boot/archiso.img', '/arch_minimal/'), - ('/arch/boot/vmlinuz', '/arch_minimal/'), - ('/arch/pkglist.x86_64.txt', '/arch_minimal/'), - ('/arch/x86_64', '/arch_minimal/'), - ) -ITEMS_WINPE = ( - ('/bootmgr', '/'), - ('/bootmgr.efi', '/'), - ('/en_us', '/'), - ('/Boot/', '/boot/'), - ('/EFI/Boot/', '/EFI/Microsoft/'), - ('/EFI/Microsoft/', '/EFI/Microsoft/'), - ('/Boot/BCD', '/sources/'), - ('/Boot/boot.sdi', '/sources/'), - ('/bootmgr', '/sources/'), - ('/sources/boot.wim', '/sources/'), - ) +ITEMS = { + 'Extra Dir': ( + ('/', '/'), + ), + 'Linux': ( + ('/arch', '/'), + ('/isolinux', '/'), + ('/EFI/boot', '/EFI/'), + ('/EFI/memtest86', '/EFI/'), + ), + 'Linux (Minimal)': ( + ('/arch/boot/archiso.img', '/arch_minimal/'), + ('/arch/boot/vmlinuz', '/arch_minimal/'), + ('/arch/pkglist.x86_64.txt', '/arch_minimal/'), + ('/arch/x86_64', '/arch_minimal/'), + ), + 'Main Kit': ( + ('/', '/{}/'.format(KIT_NAME_FULL)), + ), + 'WinPE': ( + ('/bootmgr', '/'), + ('/bootmgr.efi', '/'), + ('/en_us', '/'), + ('/Boot/', '/boot/'), + ('/EFI/Boot/', '/EFI/Microsoft/'), + ('/EFI/Microsoft/', '/EFI/Microsoft/'), + ('/Boot/BCD', '/sources/'), + ('/Boot/boot.sdi', '/sources/'), + ('/bootmgr', '/sources/'), + ('/sources/boot.wim', '/sources/'), + ), + } if __name__ == '__main__': print("This file is not meant to be called directly.") From 8cdb834499670a73059008d7f736d48b01291239 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 02:59:03 -0700 Subject: [PATCH 12/75] Initial, incomplete version of recursive_copy() --- .bin/Scripts/functions/ufd.py | 40 +++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index ae1bc37d..92782d12 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -75,6 +75,46 @@ def is_valid_path(path_obj, path_type): return valid_path +def recursive_copy(source, dest, overwrite=True): + """Copy source to dest recursively. + + NOTE: This uses rsync style source/dest syntax. + If the source has a trailing slash then it's contents are copied, + otherwise the source itself is copied. + + Examples assuming "ExDir/ExFile.txt" exists: + recursive_copy("ExDir", "Dest/") results in "Dest/ExDir/ExFile.txt" + recursive_copy("ExDir/", "Dest/") results in "Dest/ExFile.txt" + + NOTE 2: dest does not use find_path because it might not exist. + """ + copy_contents = source.endswith('/') + source = find_path(source) + dest = pathlib.Path(dest) + + if copy_contents: + for item in os.scandir(source): + recursive_copy(item.path, dest, overwrite=overwrite) + elif source.is_dir(): + if not dest.exists(): + shutil.copytree(source, dest.joinpath('source.name')) + elif not dest.is_dir(): + raise GenericError('Unexpected item in dest: {}'.format(dest)) + else: + # Dest exists and is a dir + for item in os.scandir(source): + recursive_copy( + item.path, + dest.joinpath(source.name), + overwrite=overwrite, + ) + elif source.is_file(): + # TODO FIXME + if dest.exists(): + # TODO FIXME + pass + + if __name__ == '__main__': print("This file is not meant to be called directly.") From 14ebc23b81aebf7d125fdbc534373da624166eef Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 17:39:43 -0700 Subject: [PATCH 13/75] Fix issue #101 --- .linux_items/packages/live_add | 1 + 1 file changed, 1 insertion(+) diff --git a/.linux_items/packages/live_add b/.linux_items/packages/live_add index 668c10c0..92b92a6c 100644 --- a/.linux_items/packages/live_add +++ b/.linux_items/packages/live_add @@ -32,6 +32,7 @@ p7zip progsreiserfs python python-psutil +python-pytz python-requests reiserfsprogs rfkill From 4d9ab2215bed296d54803055cf2d9164e2c4995f Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 18:57:38 -0700 Subject: [PATCH 14/75] Ensure SMART values are shown for some disks * smartctl can return non-zero if there are errors in the SMART logs --- .bin/Scripts/functions/hw_diags.py | 2 +- .bin/Scripts/functions/json.py | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.bin/Scripts/functions/hw_diags.py b/.bin/Scripts/functions/hw_diags.py index f5235111..4b018447 100644 --- a/.bin/Scripts/functions/hw_diags.py +++ b/.bin/Scripts/functions/hw_diags.py @@ -350,7 +350,7 @@ class DiskObj(): def get_smart_details(self): """Get data from smartctl.""" cmd = ['sudo', 'smartctl', '--all', '--json', self.path] - self.smartctl = get_json_from_command(cmd) + self.smartctl = get_json_from_command(cmd, check=False) # Check for attributes if KEY_NVME in self.smartctl: diff --git a/.bin/Scripts/functions/json.py b/.bin/Scripts/functions/json.py index b4527c0d..49481903 100644 --- a/.bin/Scripts/functions/json.py +++ b/.bin/Scripts/functions/json.py @@ -4,7 +4,7 @@ import json from functions.common import * -def get_json_from_command(cmd, ignore_errors=True): +def get_json_from_command(cmd, check=True, ignore_errors=True): """Capture JSON content from cmd output, returns dict. If the data can't be decoded then either an exception is raised @@ -17,7 +17,7 @@ def get_json_from_command(cmd, ignore_errors=True): errors = 'ignore' try: - result = run_program(cmd, encoding='utf-8', errors=errors) + result = run_program(cmd, check=check, encoding='utf-8', errors=errors) json_data = json.loads(result.stdout) except (subprocess.CalledProcessError, json.decoder.JSONDecodeError): if not ignore_errors: From 415f56863d89b9f54946232526a24d536a7be217 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 20:26:41 -0700 Subject: [PATCH 15/75] Finished recursive_copy() --- .bin/Scripts/functions/ufd.py | 49 +++++++++++++++++++++-------------- 1 file changed, 29 insertions(+), 20 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 92782d12..3671a262 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -90,29 +90,38 @@ def recursive_copy(source, dest, overwrite=True): """ copy_contents = source.endswith('/') source = find_path(source) - dest = pathlib.Path(dest) + dest = pathlib.Path(dest).resolve().joinpath(source.name) + os.makedirs(dest.parent, exist_ok=True) - if copy_contents: - for item in os.scandir(source): - recursive_copy(item.path, dest, overwrite=overwrite) - elif source.is_dir(): - if not dest.exists(): - shutil.copytree(source, dest.joinpath('source.name')) - elif not dest.is_dir(): - raise GenericError('Unexpected item in dest: {}'.format(dest)) - else: - # Dest exists and is a dir + if source.is_dir(): + if copy_contents: + # Trailing slash syntax for item in os.scandir(source): - recursive_copy( - item.path, - dest.joinpath(source.name), - overwrite=overwrite, - ) + recursive_copy(item.path, dest.parent, overwrite=overwrite) + elif not dest.exists(): + # No conflict, copying whole tree (no merging needed) + shutil.copytree(source, dest) + elif not dest.is_dir(): + # Refusing to replace file with dir + raise GenericError('Refusing to replace file with dir: {}'.format(dest)) + else: + # Dest exists and is a dir, merge dirs + for item in os.scandir(source): + recursive_copy(item.path, dest, overwrite=overwrite) elif source.is_file(): - # TODO FIXME - if dest.exists(): - # TODO FIXME - pass + if not dest.exists(): + # No conflict, copying file + shutil.copy2(source, dest) + elif not dest.is_file(): + # Refusing to replace dir with file + raise GenericError('Refusing to replace dir with file: {}'.format(dest)) + elif overwrite: + # Dest file exists, deleting and replacing file + os.remove(dest) + shutil.copy2(source, dest) + else: + # Refusing to delete file when overwrite=False + raise GenericError('Refusing to delete file: {}'.format(dest)) if __name__ == '__main__': From 1a8b6705e01a1c9bb71dd654eff764f7c2bfede9 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 8 Apr 2019 20:57:35 -0700 Subject: [PATCH 16/75] Show selections before starting work --- .bin/Scripts/build-ufd | 54 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 9c048dea..2f7f7451 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -47,6 +47,60 @@ if __name__ == '__main__': sources[label] = s_path_obj # Show selections + ## Header + clear_screen() + print_success(KIT_NAME_FULL) + print_standard('UFD Build Tool') + print_standard(' ') + ## Sources + print_info('Sources') + for label in UFD_SOURCES.keys(): + if label in sources: + print_standard(' {label:<18} {path}'.format( + label=label+':', + path=sources[label], + )) + else: + print_standard(' {label:<18} {YELLOW}Not Specified{CLEAR}'.format( + label=label+':', + **COLORS, + )) + ## Destination + print_standard(' ') + print_info('Destination') + cmd = [ + 'lsblk', '--nodeps', '--noheadings', + '--output', 'NAME,TRAN,SIZE,VENDOR,MODEL,SERIAL', + ] + result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') + print_standard(result.stdout.strip()) + cmd = [ + 'lsblk', '--noheadings', + '--output', 'NAME,SIZE,FSTYPE,LABEL,MOUNTPOINT', + ] + result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') + for line in result.stdout.splitlines()[1:]: + print_standard(line) + if args['--use-mbr'] and not args['--update']: + print_warning('Formatting using legacy MBR') + print_standard(' ') + if not ask('Is the above information correct?'): + abort() + ## Safety check + print_standard(' ') + print_warning('SAFETY CHECK') + print_standard( + 'All data will be DELETED from the disk and partition(s) listed above.') + print_standard( + 'This is irreversible and will lead to {RED}DATA LOSS.{CLEAR}'.format( + **COLORS)) + if not ask('Asking again to confirm, is this correct?'): + abort() + + print_standard(' ') + print_success("It's go-time!") + exit_script(1) + # TODO FIXME print_standard('UFD: {}'.format(ufd_dev)) print_standard('Sources:') From d33f78960d81d4db3d551f61384fe06a6df2ccf4 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 20:50:21 -0700 Subject: [PATCH 17/75] Reduced imports --- .bin/Scripts/build-ufd | 1 + .bin/Scripts/functions/ufd.py | 16 +++++++++------- .bin/Scripts/settings/ufd.py | 10 +++++----- 3 files changed, 15 insertions(+), 12 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 2f7f7451..a2f47a7e 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -9,6 +9,7 @@ import sys sys.path.append(os.path.dirname(os.path.realpath(__file__))) from collections import OrderedDict from docopt import docopt +from functions.common import * from functions.ufd import * from settings.ufd import * init_global_vars() diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 3671a262..e8fb164f 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -1,7 +1,9 @@ # Wizard Kit: Functions - UFD +import os +import re +import shutil import pathlib -from functions.common import * def case_insensitive_search(path, item): @@ -27,11 +29,11 @@ def case_insensitive_search(path, item): ) # Done - if real_path: - return real_path - else: + if not real_path: raise FileNotFoundError('{}/{}'.format(path, item)) + return real_path + def find_path(path): """Find path case-insensitively, returns pathlib.Path obj.""" @@ -103,7 +105,7 @@ def recursive_copy(source, dest, overwrite=True): shutil.copytree(source, dest) elif not dest.is_dir(): # Refusing to replace file with dir - raise GenericError('Refusing to replace file with dir: {}'.format(dest)) + raise FileExistsError('Refusing to replace file: {}'.format(dest)) else: # Dest exists and is a dir, merge dirs for item in os.scandir(source): @@ -114,14 +116,14 @@ def recursive_copy(source, dest, overwrite=True): shutil.copy2(source, dest) elif not dest.is_file(): # Refusing to replace dir with file - raise GenericError('Refusing to replace dir with file: {}'.format(dest)) + raise FileExistsError('Refusing to replace dir: {}'.format(dest)) elif overwrite: # Dest file exists, deleting and replacing file os.remove(dest) shutil.copy2(source, dest) else: # Refusing to delete file when overwrite=False - raise GenericError('Refusing to delete file: {}'.format(dest)) + raise FileExistsError('Refusing to delete file: {}'.format(dest)) if __name__ == '__main__': diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index 4f99018c..13ecd4e9 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -1,7 +1,9 @@ -# Wizard Kit: Settings - UFD +'''Wizard Kit: Settings - UFD''' +# pylint: disable=C0326,E0611 +# vim: sts=2 sw=2 ts=2 from collections import OrderedDict -from settings.main import * +from settings.main import KIT_NAME_FULL,KIT_NAME_SHORT # General DOCSTRING = '''WizardKit: Build UFD @@ -31,7 +33,7 @@ Options: ''' ISO_LABEL = '{}_LINUX'.format(KIT_NAME_SHORT) UFD_LABEL = '{}_UFD'.format(KIT_NAME_SHORT) -UFD_SOURCES = ({ +UFD_SOURCES = OrderedDict({ 'Linux': {'Arg': '--linux', 'Type': 'ISO'}, 'Linux (Minimal)': {'Arg': '--linux-minimal', 'Type': 'ISO'}, 'WinPE': {'Arg': '--winpe', 'Type': 'ISO'}, @@ -84,5 +86,3 @@ ITEMS = { if __name__ == '__main__': print("This file is not meant to be called directly.") - -# vim: sts=2 sw=2 ts=2 From a8afd793e0dc035024be29aee6de6beafc66c3a8 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 20:55:40 -0700 Subject: [PATCH 18/75] Added setup-wifi script * This will replace the connect_to_network() function --- .bin/Scripts/setup-wifi | 72 +++++++++++++++++++++++++++++++++++++ .linux_items/known_networks | 2 ++ 2 files changed, 74 insertions(+) create mode 100644 .bin/Scripts/setup-wifi create mode 100644 .linux_items/known_networks diff --git a/.bin/Scripts/setup-wifi b/.bin/Scripts/setup-wifi new file mode 100644 index 00000000..6047c438 --- /dev/null +++ b/.bin/Scripts/setup-wifi @@ -0,0 +1,72 @@ +#!/bin/env python3 +# +## Convert saved WiFi connections for NetworkManager + +import os +import re +import uuid + +KNOWN_NETWORKS = '/root/known_networks' +TEMPLATE = '''[connection] +id={ssid} +uuid={uuid} +type=wifi +permissions=user:{user}:; + +[wifi] +mac-address-blacklist= +mode=infrastructure +ssid={ssid} + +[wifi-security] +auth-alg=open +key-mgmt=wpa-psk +psk={password} + +[ipv4] +dns-search= +method=auto + +[ipv6] +addr-gen-mode=stable-privacy +dns-search= +method=auto +''' + +def get_user_name(): + """Get real user name, returns str.""" + user = None + if 'SUDO_USER' in os.environ: + user = os.environ.get('SUDO_USER') + else: + user = os.environ.get('USER') + + return user + +if __name__ == '__main__': + known_networks = {} + #try: + with open('/root/known_networks', 'r') as f: + for line in f.readlines(): + r = re.search(r"^'(.*)':\s+'(.*)'", line.strip()) + if r: + known_networks[r.group(1)] = r.group(2) + for ssid, password in known_networks.items(): + out_path = '{}/{}.nmconnection'.format( + '/etc/NetworkManager/system-connections', + password, + ) + if not os.path.exists(out_path): + with open(out_path, 'w') as f: + f.write(TEMPLATE.format( + user=get_user_name(), + ssid=ssid, + password=password, + uuid=uuid.uuid4(), + )) + os.chmod(out_path, 0o600) + #except: + # # Meh + # pass + +# vim: sts=2 sw=2 ts=2 diff --git a/.linux_items/known_networks b/.linux_items/known_networks new file mode 100644 index 00000000..7f110889 --- /dev/null +++ b/.linux_items/known_networks @@ -0,0 +1,2 @@ +#Put WiFi network info here +#'WiFi SSID': 'WiFi Password' From ceb6a9e294376ea884bae1f0d7fb49653973db44 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 20:57:30 -0700 Subject: [PATCH 19/75] Use setup-wifi instead of connect-to-network --- .linux_items/include/airootfs/etc/skel/.update_network | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.linux_items/include/airootfs/etc/skel/.update_network b/.linux_items/include/airootfs/etc/skel/.update_network index e7119a37..f518623e 100755 --- a/.linux_items/include/airootfs/etc/skel/.update_network +++ b/.linux_items/include/airootfs/etc/skel/.update_network @@ -3,9 +3,9 @@ # ## Connect to network and update hostname -# Connect -connect-to-network -sleep 2s +# Add saved networks to NetworkManager +sudo setup-wifi +sudo systemctl restart NetworkManager IP="$(ip a show scope global \ | grep inet \ From c4755124a0b9e9b69349fcc91fa2cac41bc1bbf0 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 20:59:42 -0700 Subject: [PATCH 20/75] Remove more connect-to-network sections --- .bin/Scripts/connect-to-network | 30 ------------------------------ .bin/Scripts/functions/network.py | 21 --------------------- .bin/Scripts/settings/main.py | 3 --- 3 files changed, 54 deletions(-) delete mode 100755 .bin/Scripts/connect-to-network diff --git a/.bin/Scripts/connect-to-network b/.bin/Scripts/connect-to-network deleted file mode 100755 index 02500b37..00000000 --- a/.bin/Scripts/connect-to-network +++ /dev/null @@ -1,30 +0,0 @@ -#!/bin/python3 -# -## Wizard Kit: Network connection tool - -import os -import sys - -# Init -sys.path.append(os.path.dirname(os.path.realpath(__file__))) -from functions.network import * -init_global_vars() - -if __name__ == '__main__': - try: - # Prep - clear_screen() - - # Connect - connect_to_network() - - # Done - print_standard('\nDone.') - #pause("Press Enter to exit...") - exit_script() - except SystemExit: - pass - except: - major_exception() - -# vim: sts=2 sw=2 ts=2 diff --git a/.bin/Scripts/functions/network.py b/.bin/Scripts/functions/network.py index 492ba16f..5b5d4f52 100644 --- a/.bin/Scripts/functions/network.py +++ b/.bin/Scripts/functions/network.py @@ -15,27 +15,6 @@ REGEX_VALID_IP = re.compile( re.IGNORECASE) -def connect_to_network(): - """Connect to network if not already connected.""" - net_ifs = psutil.net_if_addrs() - net_ifs = [i[:2] for i in net_ifs.keys()] - - # Bail if currently connected - if is_connected(): - return - - # WiFi - if 'wl' in net_ifs: - cmd = [ - 'nmcli', 'dev', 'wifi', - 'connect', WIFI_SSID, - 'password', WIFI_PASSWORD] - try_and_print( - message = 'Connecting to {}...'.format(WIFI_SSID), - function = run_program, - cmd = cmd) - - def is_connected(): """Check for a valid private IP.""" devs = psutil.net_if_addrs() diff --git a/.bin/Scripts/settings/main.py b/.bin/Scripts/settings/main.py index 99011cf9..9b478feb 100644 --- a/.bin/Scripts/settings/main.py +++ b/.bin/Scripts/settings/main.py @@ -21,9 +21,6 @@ QUICKBOOKS_SERVER_IP='10.0.0.10' # Time Zones LINUX_TIME_ZONE='America/Denver' # See 'timedatectl list-timezones' for valid values WINDOWS_TIME_ZONE='Mountain Standard Time' # See 'tzutil /l' for valid values -# WiFi -WIFI_SSID='SomeWiFi' -WIFI_PASSWORD='Abracadabra' # SERVER VARIABLES ## NOTE: Windows can only use one user per server. This means that if From d113d710a768bcbc3f292f2fb8ef8fd6e6688ab6 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 21:00:32 -0700 Subject: [PATCH 21/75] Avoid dig errors if not connected to a network --- .linux_items/include/airootfs/etc/skel/.update_network | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/.linux_items/include/airootfs/etc/skel/.update_network b/.linux_items/include/airootfs/etc/skel/.update_network index f518623e..be604a52 100755 --- a/.linux_items/include/airootfs/etc/skel/.update_network +++ b/.linux_items/include/airootfs/etc/skel/.update_network @@ -11,10 +11,12 @@ IP="$(ip a show scope global \ | grep inet \ | head -1 \ | sed -r 's#.*inet ([0-9]+.[0-9]+.[0-9]+.[0-9]+.)/.*#\1#')" -HOSTNAME="$(dig +noall +answer +short -x "$IP" \ - | grep -v ';' \ - | head -1 \ - | sed 's/\.$//')" +if [[ "${IP:+x}" ]]; then + HOSTNAME="$(dig +noall +answer +short -x "$IP" \ + | grep -v ';' \ + | head -1 \ + | sed 's/\.$//')" +fi # Set hostname if [[ "${HOSTNAME:+x}" ]]; then From c3ebdee5d008bee97f9e171ed871d336d5848a8a Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 21:14:32 -0700 Subject: [PATCH 22/75] Only update hostname when necessary * If $IP was empty then HOSTNAME would remain set to the current HOSTNAME * This allowed the redundant set-hostname call --- .../include/airootfs/etc/skel/.update_network | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/.linux_items/include/airootfs/etc/skel/.update_network b/.linux_items/include/airootfs/etc/skel/.update_network index be604a52..0b66717f 100755 --- a/.linux_items/include/airootfs/etc/skel/.update_network +++ b/.linux_items/include/airootfs/etc/skel/.update_network @@ -1,25 +1,23 @@ -## .update_network ## #!/bin/env bash # -## Connect to network and update hostname +## Setup network and update hostname # Add saved networks to NetworkManager sudo setup-wifi sudo systemctl restart NetworkManager +# Set hostname IP="$(ip a show scope global \ | grep inet \ | head -1 \ | sed -r 's#.*inet ([0-9]+.[0-9]+.[0-9]+.[0-9]+.)/.*#\1#')" if [[ "${IP:+x}" ]]; then - HOSTNAME="$(dig +noall +answer +short -x "$IP" \ + NEW_HOSTNAME="$(dig +noall +answer +short -x "$IP" \ | grep -v ';' \ | head -1 \ | sed 's/\.$//')" fi - -# Set hostname -if [[ "${HOSTNAME:+x}" ]]; then - sudo hostnamectl set-hostname "${HOSTNAME}" +if [[ "${NEW_HOSTNAME:+x}" ]]; then + sudo hostnamectl set-hostname "${NEW_HOSTNAME}" fi From 56ca60525731c2e8d6e4d4c9afbc9c0fe802054c Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 21:30:53 -0700 Subject: [PATCH 23/75] Regularly update conky config * This should allow USB adapters to be shown if connected after login --- .../timers.target.wants/update-conky.timer | 1 + .../.config/systemd/user/update-conky.service | 6 ++++ .../.config/systemd/user/update-conky.timer | 10 +++++++ .../etc/skel/{.conkyrc => .conkyrc_base} | 0 .../include_x/airootfs/etc/skel/.update_conky | 30 +++++++++++-------- 5 files changed, 35 insertions(+), 12 deletions(-) create mode 120000 .linux_items/include_x/airootfs/etc/skel/.config/systemd/user/timers.target.wants/update-conky.timer create mode 100644 .linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.service create mode 100644 .linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.timer rename .linux_items/include_x/airootfs/etc/skel/{.conkyrc => .conkyrc_base} (100%) diff --git a/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/timers.target.wants/update-conky.timer b/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/timers.target.wants/update-conky.timer new file mode 120000 index 00000000..dc3ece34 --- /dev/null +++ b/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/timers.target.wants/update-conky.timer @@ -0,0 +1 @@ +../update-conky.timer \ No newline at end of file diff --git a/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.service b/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.service new file mode 100644 index 00000000..d2048e93 --- /dev/null +++ b/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.service @@ -0,0 +1,6 @@ +[Unit] +Description=Conky config update service + +[Service] +Type=oneshot +ExecStart=%h/.update_conky diff --git a/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.timer b/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.timer new file mode 100644 index 00000000..c742a10a --- /dev/null +++ b/.linux_items/include_x/airootfs/etc/skel/.config/systemd/user/update-conky.timer @@ -0,0 +1,10 @@ +[Unit] +Description=Conky config update timer + +[Timer] +OnBootSec=5s +OnUnitActiveSec=30s +Unit=update-conky.service + +[Install] +WantedBy=timers.target diff --git a/.linux_items/include_x/airootfs/etc/skel/.conkyrc b/.linux_items/include_x/airootfs/etc/skel/.conkyrc_base similarity index 100% rename from .linux_items/include_x/airootfs/etc/skel/.conkyrc rename to .linux_items/include_x/airootfs/etc/skel/.conkyrc_base diff --git a/.linux_items/include_x/airootfs/etc/skel/.update_conky b/.linux_items/include_x/airootfs/etc/skel/.update_conky index 79801d8b..0e45e13d 100755 --- a/.linux_items/include_x/airootfs/etc/skel/.update_conky +++ b/.linux_items/include_x/airootfs/etc/skel/.update_conky @@ -1,18 +1,24 @@ #!/bin/bash -IF_LIST=($(ip l | egrep '^[0-9]+:\s+(eth|en|wl)' | sed -r 's/^[0-9]+:\s+(\w+):.*/\1/' | sort)) +IF_LIST=($(ip l \ + | egrep '^[0-9]+:\s+(eth|en|wl)' \ + | sed -r 's/^[0-9]+:\s+(\w+):.*/\1/' \ + | sort)) + +# Reset conkyrc to default +rm "${HOME}/.conkyrc" +cp "${HOME}/.conkyrc_base" "${HOME}/.conkyrc" # Add interfaces to conkyrc -if fgrep '#Network' $HOME/.conkyrc; then - for i in "${IF_LIST[@]}"; do - if [[ "${i:0:1}" == "e" ]]; then - sed -i -r "s/#Network/Wired:\${alignr}\${addr $i}\n#Network/" $HOME/.conkyrc - else - sed -i -r "s/#Network/Wireless:\${alignr}\${addr $i}\n#Network/" $HOME/.conkyrc - fi - done +for i in "${IF_LIST[@]}"; do + if [[ "${i:0:1}" == "e" ]]; then + sed -i -r "s/#Network/Wired:\${alignr}\${addr $i}\n#Network/" $HOME/.conkyrc + else + sed -i -r "s/#Network/Wireless:\${alignr}\${addr $i}\n#Network/" $HOME/.conkyrc + fi +done - # Remove '#Network' line to prevent duplicating lines if this script is re-run - sed -i -r "s/#Network//" $HOME/.conkyrc -fi +# Remove '#Network' line to prevent duplicating lines if this script is re-run +sed -i -r "s/#Network//" $HOME/.conkyrc +# vim: sts=2 sw=2 ts=2 From 23add7e27637beca0608618d4718607ac414a7d4 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 21:40:51 -0700 Subject: [PATCH 24/75] Preserve DPI settings when updating conky --- .linux_items/include_x/airootfs/etc/skel/.update_x | 11 +++++++---- .linux_items/include_x/airootfs/etc/skel/.zlogin | 3 --- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.linux_items/include_x/airootfs/etc/skel/.update_x b/.linux_items/include_x/airootfs/etc/skel/.update_x index 650d3162..c1f67cf4 100755 --- a/.linux_items/include_x/airootfs/etc/skel/.update_x +++ b/.linux_items/include_x/airootfs/etc/skel/.update_x @@ -32,10 +32,10 @@ offset_urxvt="24" # Update settings if necessary if [[ "${dpi}" -ge 192 ]]; then # Conky - sed -i 's/minimum_size 180 0/minimum_size 360 0/' "${HOME}/.conkyrc" - sed -i 's/maximum_width 180/maximum_width 360/' "${HOME}/.conkyrc" - sed -i 's/gap_x 20/gap_x 40/' "${HOME}/.conkyrc" - sed -i 's/gap_y 24/gap_y 48/' "${HOME}/.conkyrc" + sed -i 's/minimum_size 180 0/minimum_size 360 0/' "${HOME}/.conkyrc_base" + sed -i 's/maximum_width 180/maximum_width 360/' "${HOME}/.conkyrc_base" + sed -i 's/gap_x 20/gap_x 40/' "${HOME}/.conkyrc_base" + sed -i 's/gap_y 24/gap_y 48/' "${HOME}/.conkyrc_base" # Fonts sed -i 's/!Xft.dpi: 192/Xft.dpi: 192/' "${HOME}/.Xresources" @@ -67,6 +67,9 @@ fi urxvt_geometry="${width_urxvt}x${height_urxvt}+${offset_urxvt}+${offset_urxvt}" sed -i -r "s/${REGEX_URXVT}/\1${urxvt_geometry}/" "${HOME}/.Xresources" +# Update conky +$HOME/.update_conky + # Update X xset s off xset -dpms diff --git a/.linux_items/include_x/airootfs/etc/skel/.zlogin b/.linux_items/include_x/airootfs/etc/skel/.zlogin index 04b1316e..8901bb31 100644 --- a/.linux_items/include_x/airootfs/etc/skel/.zlogin +++ b/.linux_items/include_x/airootfs/etc/skel/.zlogin @@ -9,9 +9,6 @@ if [ "$(fgconsole 2>/dev/null)" -eq "1" ]; then sed -i -r 's/openbox-session/i3/' ~/.xinitrc fi - # Update Conky - $HOME/.update_conky - # Start X or HW-diags if ! fgrep -q "nox" /proc/cmdline; then # Kill Xorg after 30 seconds if it doesn't fully initialize From 0883b099fd7c83aa56d11553940bec15c2bbc6a7 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 22:24:25 -0700 Subject: [PATCH 25/75] Skip safety check if upgrading --- .bin/Scripts/build-ufd | 29 +++++++++++++---------------- 1 file changed, 13 insertions(+), 16 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index a2f47a7e..05458c6b 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -82,32 +82,29 @@ if __name__ == '__main__': result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') for line in result.stdout.splitlines()[1:]: print_standard(line) - if args['--use-mbr'] and not args['--update']: + if args['--update']: + print_warning('Updating kit in-place') + elif args['--use-mbr']: print_warning('Formatting using legacy MBR') print_standard(' ') if not ask('Is the above information correct?'): abort() ## Safety check - print_standard(' ') - print_warning('SAFETY CHECK') - print_standard( - 'All data will be DELETED from the disk and partition(s) listed above.') - print_standard( - 'This is irreversible and will lead to {RED}DATA LOSS.{CLEAR}'.format( - **COLORS)) - if not ask('Asking again to confirm, is this correct?'): - abort() + if not args['--update']: + print_standard(' ') + print_warning('SAFETY CHECK') + print_standard( + 'All data will be DELETED from the disk and partition(s) listed above.') + print_standard( + 'This is irreversible and will lead to {RED}DATA LOSS.{CLEAR}'.format( + **COLORS)) + if not ask('Asking again to confirm, is this correct?'): + abort() print_standard(' ') print_success("It's go-time!") exit_script(1) - # TODO FIXME - print_standard('UFD: {}'.format(ufd_dev)) - print_standard('Sources:') - for label, s_path in sources.items(): - print_standard(' {:<16} {}'.format(label+':', s_path)) - # Double-check if formating device # Format and partition device From b2528b90f8abc4a35672ff707c4e561e4d925c55 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 11 Apr 2019 22:25:13 -0700 Subject: [PATCH 26/75] Fix docopt handling * Show usage if invalid arguments are used --- .bin/Scripts/build-ufd | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 05458c6b..726efa4d 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -20,6 +20,13 @@ set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) if __name__ == '__main__': try: args = docopt(DOCSTRING) + except SystemExit as err: + # Catch docopt exits + print(err) + exit_script() + except: + major_exception() + try: sources = OrderedDict() # Verify selections From 5a1f7b1829a20f8e46fd669341064cb9108ce916 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 15:58:09 -0700 Subject: [PATCH 27/75] Silence build-ufd init --- .bin/Scripts/build-ufd | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 726efa4d..c4fcb26a 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -12,7 +12,7 @@ from docopt import docopt from functions.common import * from functions.ufd import * from settings.ufd import * -init_global_vars() +init_global_vars(silent=True) set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) From d62a647fa9cfe90dc14aaa9f9d609c72cd1bf8b8 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 16:46:50 -0700 Subject: [PATCH 28/75] Avoid setting LogDir to /root/Logs under su/sudo --- .bin/Scripts/build-ufd | 34 ++++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index c4fcb26a..d83eddf2 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -13,11 +13,36 @@ from functions.common import * from functions.ufd import * from settings.ufd import * init_global_vars(silent=True) -set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) + +# Functions +def get_user_home(user): + """Get path to user's home dir, returns str.""" + home_dir = None + cmd = ['getent', 'passwd', user] + result = run_program(cmd, encoding='utf-8', errors='ignore', check=False) + try: + home_dir = result.stdout.split(':')[5] + except Exception: + # Just use HOME from ENV (or '/root' if that fails) + home_dir = os.environ.get('HOME', '/root') + + return home_dir + + +def get_user_name(): + """Get real user name, returns str.""" + user = None + if 'SUDO_USER' in os.environ: + user = os.environ.get('SUDO_USER') + else: + user = os.environ.get('USER') + + return user # Main section if __name__ == '__main__': + # Docopt try: args = docopt(DOCSTRING) except SystemExit as err: @@ -26,10 +51,15 @@ if __name__ == '__main__': exit_script() except: major_exception() + try: - sources = OrderedDict() + # Set log + global_vars['LogDir'] = '{}/Logs'.format( + get_user_home(get_user_name())) + set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) # Verify selections + sources = OrderedDict() ## UFD try: ufd_dev = find_path(args['--ufd-device']) From fde9be6b3ff16cdd9c709ab5929f1cc3f6e3c928 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 16:48:34 -0700 Subject: [PATCH 29/75] Updated get_user_name() --- .bin/Scripts/build-ufd | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index d83eddf2..610a1e66 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -33,9 +33,9 @@ def get_user_name(): """Get real user name, returns str.""" user = None if 'SUDO_USER' in os.environ: - user = os.environ.get('SUDO_USER') + user = os.environ.get('SUDO_USER', 'Unknown') else: - user = os.environ.get('USER') + user = os.environ.get('USER', 'Unknown') return user From 6734460d42d553551b2986c159859255e243509c Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 17:01:53 -0700 Subject: [PATCH 30/75] Added option to skip pause in abort() * Also use exit_script(1) --- .bin/Scripts/build-ufd | 12 ++++++------ .bin/Scripts/functions/common.py | 9 +++++---- 2 files changed, 11 insertions(+), 10 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 610a1e66..5542a0ac 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -66,10 +66,10 @@ if __name__ == '__main__': except FileNotFoundError: print_error('ERROR: UFD device not found: {}'.format( args['--ufd-device'])) - abort() + abort(False) if not is_valid_path(ufd_dev, 'UFD'): print_error('ERROR: Invalid UFD device: {}'.format(ufd_dev)) - abort() + abort(False) ## Sources for label, data in UFD_SOURCES.items(): s_path = args[data['Arg']] @@ -78,10 +78,10 @@ if __name__ == '__main__': s_path_obj = find_path(s_path) except FileNotFoundError: print_error('ERROR: {} not found: {}'.format(label, s_path)) - abort() + abort(False) if not is_valid_path(s_path_obj, data['Type']): print_error('ERROR: Invalid {} source: {}'.format(label, s_path)) - abort() + abort(False) sources[label] = s_path_obj # Show selections @@ -125,7 +125,7 @@ if __name__ == '__main__': print_warning('Formatting using legacy MBR') print_standard(' ') if not ask('Is the above information correct?'): - abort() + abort(False) ## Safety check if not args['--update']: print_standard(' ') @@ -136,7 +136,7 @@ if __name__ == '__main__': 'This is irreversible and will lead to {RED}DATA LOSS.{CLEAR}'.format( **COLORS)) if not ask('Asking again to confirm, is this correct?'): - abort() + abort(False) print_standard(' ') print_success("It's go-time!") diff --git a/.bin/Scripts/functions/common.py b/.bin/Scripts/functions/common.py index b6008d27..fe75f1ef 100644 --- a/.bin/Scripts/functions/common.py +++ b/.bin/Scripts/functions/common.py @@ -90,12 +90,13 @@ class SecureBootUnknownError(Exception): # General functions -def abort(): +def abort(show_prompt=True): """Abort script.""" print_warning('Aborted.') - sleep(1) - pause(prompt='Press Enter to exit... ') - exit_script() + if show_prompt: + sleep(timeout) + pause(prompt='Press Enter to exit... ') + exit_script(1) def ask(prompt='Kotaero!'): From cc1a318e3dece2dab58c85dcdd5ec7387da86ecc Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 17:03:04 -0700 Subject: [PATCH 31/75] Abort if not running as root --- .bin/Scripts/build-ufd | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 5542a0ac..38b6f8d6 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -42,6 +42,11 @@ def get_user_name(): # Main section if __name__ == '__main__': + # Check if running as root + if os.geteuid() != 0: + print_error('ERROR: This script is meant to be run as root.') + abort(False) + # Docopt try: args = docopt(DOCSTRING) From cf1d11eb789280ddf9eb44aac2cb37363a8460be Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 17:16:13 -0700 Subject: [PATCH 32/75] Always show header --- .bin/Scripts/build-ufd | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 38b6f8d6..592a6143 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -42,6 +42,19 @@ def get_user_name(): # Main section if __name__ == '__main__': + # Set log + try: + global_vars['LogDir'] = '{}/Logs'.format( + get_user_home(get_user_name())) + set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) + except: + major_exception() + + # Header + print_success(KIT_NAME_FULL) + print_standard('UFD Build Tool') + print_standard(' ') + # Check if running as root if os.geteuid() != 0: print_error('ERROR: This script is meant to be run as root.') @@ -58,11 +71,6 @@ if __name__ == '__main__': major_exception() try: - # Set log - global_vars['LogDir'] = '{}/Logs'.format( - get_user_home(get_user_name())) - set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) - # Verify selections sources = OrderedDict() ## UFD @@ -90,11 +98,6 @@ if __name__ == '__main__': sources[label] = s_path_obj # Show selections - ## Header - clear_screen() - print_success(KIT_NAME_FULL) - print_standard('UFD Build Tool') - print_standard(' ') ## Sources print_info('Sources') for label in UFD_SOURCES.keys(): @@ -145,7 +148,7 @@ if __name__ == '__main__': print_standard(' ') print_success("It's go-time!") - exit_script(1) + exit_script() # Double-check if formating device From 1b312658e949a93cfafbdc9dd4b3772671678af6 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 17:17:11 -0700 Subject: [PATCH 33/75] Fixed return code handling --- .bin/Scripts/build-ufd | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 592a6143..3b688e17 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -42,6 +42,7 @@ def get_user_name(): # Main section if __name__ == '__main__': + return_code = 0 # Set log try: global_vars['LogDir'] = '{}/Logs'.format( @@ -169,10 +170,11 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter to exit...') exit_script() - except SystemExit: - pass + except SystemExit as e: + return_code = e.code except: major_exception() + exit_script(return_code) # vim: sts=2 sw=2 ts=2 From 0e6be3ad08620de0042beffa8ca3694ab63b9534 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 17:57:46 -0700 Subject: [PATCH 34/75] Better SystemExit handling --- .bin/Scripts/build-ufd | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 3b688e17..cfb19124 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -42,7 +42,6 @@ def get_user_name(): # Main section if __name__ == '__main__': - return_code = 0 # Set log try: global_vars['LogDir'] = '{}/Logs'.format( @@ -170,11 +169,9 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter to exit...') exit_script() - except SystemExit as e: - return_code = e.code + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() - exit_script(return_code) - # vim: sts=2 sw=2 ts=2 From 164fd4c646d6df829ec4c646cdd367bbea7f3ecc Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 18:09:36 -0700 Subject: [PATCH 35/75] Fixed SystemExit calls from docopt --- .bin/Scripts/build-ufd | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index cfb19124..15e4e680 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -63,10 +63,9 @@ if __name__ == '__main__': # Docopt try: args = docopt(DOCSTRING) - except SystemExit as err: + except SystemExit as sys_exit: # Catch docopt exits - print(err) - exit_script() + exit_script(sys_exit.code) except: major_exception() From 3310e3d2537f49c9d6d655f64cc17a1300e240c9 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 18:43:08 -0700 Subject: [PATCH 36/75] Moved most logic to functions.ufd --- .bin/Scripts/build-ufd | 108 ++-------------------------- .bin/Scripts/functions/ufd.py | 131 ++++++++++++++++++++++++++++++++++ 2 files changed, 137 insertions(+), 102 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 15e4e680..887932a7 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -7,39 +7,12 @@ import sys # Init sys.path.append(os.path.dirname(os.path.realpath(__file__))) -from collections import OrderedDict from docopt import docopt from functions.common import * from functions.ufd import * from settings.ufd import * init_global_vars(silent=True) -# Functions -def get_user_home(user): - """Get path to user's home dir, returns str.""" - home_dir = None - cmd = ['getent', 'passwd', user] - result = run_program(cmd, encoding='utf-8', errors='ignore', check=False) - try: - home_dir = result.stdout.split(':')[5] - except Exception: - # Just use HOME from ENV (or '/root' if that fails) - home_dir = os.environ.get('HOME', '/root') - - return home_dir - - -def get_user_name(): - """Get real user name, returns str.""" - user = None - if 'SUDO_USER' in os.environ: - user = os.environ.get('SUDO_USER', 'Unknown') - else: - user = os.environ.get('USER', 'Unknown') - - return user - - # Main section if __name__ == '__main__': # Set log @@ -56,7 +29,7 @@ if __name__ == '__main__': print_standard(' ') # Check if running as root - if os.geteuid() != 0: + if not running_as_root(): print_error('ERROR: This script is meant to be run as root.') abort(False) @@ -71,81 +44,12 @@ if __name__ == '__main__': try: # Verify selections - sources = OrderedDict() - ## UFD - try: - ufd_dev = find_path(args['--ufd-device']) - except FileNotFoundError: - print_error('ERROR: UFD device not found: {}'.format( - args['--ufd-device'])) - abort(False) - if not is_valid_path(ufd_dev, 'UFD'): - print_error('ERROR: Invalid UFD device: {}'.format(ufd_dev)) - abort(False) - ## Sources - for label, data in UFD_SOURCES.items(): - s_path = args[data['Arg']] - if s_path: - try: - s_path_obj = find_path(s_path) - except FileNotFoundError: - print_error('ERROR: {} not found: {}'.format(label, s_path)) - abort(False) - if not is_valid_path(s_path_obj, data['Type']): - print_error('ERROR: Invalid {} source: {}'.format(label, s_path)) - abort(False) - sources[label] = s_path_obj + ufd_dev = verify_ufd(args['--ufd-device']) + sources = verify_sources(args, UFD_SOURCES) + show_selections(args, sources, ufd_dev, UFD_SOURCES) + confirm_selections(args) - # Show selections - ## Sources - print_info('Sources') - for label in UFD_SOURCES.keys(): - if label in sources: - print_standard(' {label:<18} {path}'.format( - label=label+':', - path=sources[label], - )) - else: - print_standard(' {label:<18} {YELLOW}Not Specified{CLEAR}'.format( - label=label+':', - **COLORS, - )) - ## Destination - print_standard(' ') - print_info('Destination') - cmd = [ - 'lsblk', '--nodeps', '--noheadings', - '--output', 'NAME,TRAN,SIZE,VENDOR,MODEL,SERIAL', - ] - result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') - print_standard(result.stdout.strip()) - cmd = [ - 'lsblk', '--noheadings', - '--output', 'NAME,SIZE,FSTYPE,LABEL,MOUNTPOINT', - ] - result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') - for line in result.stdout.splitlines()[1:]: - print_standard(line) - if args['--update']: - print_warning('Updating kit in-place') - elif args['--use-mbr']: - print_warning('Formatting using legacy MBR') - print_standard(' ') - if not ask('Is the above information correct?'): - abort(False) - ## Safety check - if not args['--update']: - print_standard(' ') - print_warning('SAFETY CHECK') - print_standard( - 'All data will be DELETED from the disk and partition(s) listed above.') - print_standard( - 'This is irreversible and will lead to {RED}DATA LOSS.{CLEAR}'.format( - **COLORS)) - if not ask('Asking again to confirm, is this correct?'): - abort(False) - - print_standard(' ') + # TODO: DELETEME print_success("It's go-time!") exit_script() diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index e8fb164f..7c7a9b48 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -4,6 +4,8 @@ import os import re import shutil import pathlib +from collections import OrderedDict +from functions.common import * def case_insensitive_search(path, item): @@ -35,6 +37,25 @@ def case_insensitive_search(path, item): return real_path +def confirm_selections(args): + """Ask tech to confirm selections, twice if necessary.""" + if not ask('Is the above information correct?'): + abort(False) + ## Safety check + if not args['--update']: + print_standard(' ') + print_warning('SAFETY CHECK') + print_standard( + 'All data will be DELETED from the disk and partition(s) listed above.') + print_standard( + 'This is irreversible and will lead to {RED}DATA LOSS.{CLEAR}'.format( + **COLORS)) + if not ask('Asking again to confirm, is this correct?'): + abort(False) + + print_standard(' ') + + def find_path(path): """Find path case-insensitively, returns pathlib.Path obj.""" path_obj = pathlib.Path(path).resolve() @@ -62,6 +83,31 @@ def find_path(path): return path_obj +def get_user_home(user): + """Get path to user's home dir, returns str.""" + home_dir = None + cmd = ['getent', 'passwd', user] + result = run_program(cmd, encoding='utf-8', errors='ignore', check=False) + try: + home_dir = result.stdout.split(':')[5] + except Exception: + # Just use HOME from ENV (or '/root' if that fails) + home_dir = os.environ.get('HOME', '/root') + + return home_dir + + +def get_user_name(): + """Get real user name, returns str.""" + user = None + if 'SUDO_USER' in os.environ: + user = os.environ.get('SUDO_USER', 'Unknown') + else: + user = os.environ.get('USER', 'Unknown') + + return user + + def is_valid_path(path_obj, path_type): """Verify path_obj is valid by type, returns bool.""" valid_path = False @@ -126,6 +172,91 @@ def recursive_copy(source, dest, overwrite=True): raise FileExistsError('Refusing to delete file: {}'.format(dest)) +def running_as_root(): + """Check if running with effective UID of 0, returns bool.""" + return os.geteuid() == 0 + + +def show_selections(args, sources, ufd_dev, ufd_sources): + """Show selections including non-specified options.""" + + # Sources + print_info('Sources') + for label in ufd_sources.keys(): + if label in sources: + print_standard(' {label:<18} {path}'.format( + label=label+':', + path=sources[label], + )) + else: + print_standard(' {label:<18} {YELLOW}Not Specified{CLEAR}'.format( + label=label+':', + **COLORS, + )) + print_standard(' ') + + # Destination + print_info('Destination') + cmd = [ + 'lsblk', '--nodeps', '--noheadings', + '--output', 'NAME,TRAN,SIZE,VENDOR,MODEL,SERIAL', + ] + result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') + print_standard(result.stdout.strip()) + cmd = [ + 'lsblk', '--noheadings', + '--output', 'NAME,SIZE,FSTYPE,LABEL,MOUNTPOINT', + ] + result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') + for line in result.stdout.splitlines()[1:]: + print_standard(line) + + # Notes + if args['--update']: + print_warning('Updating kit in-place') + elif args['--use-mbr']: + print_warning('Formatting using legacy MBR') + print_standard(' ') + + +def verify_sources(args, ufd_sources): + """Check all sources and abort if necessary, returns dict.""" + sources = OrderedDict() + + for label, data in ufd_sources.items(): + s_path = args[data['Arg']] + if s_path: + try: + s_path_obj = find_path(s_path) + except FileNotFoundError: + print_error('ERROR: {} not found: {}'.format(label, s_path)) + abort(False) + if not is_valid_path(s_path_obj, data['Type']): + print_error('ERROR: Invalid {} source: {}'.format(label, s_path)) + abort(False) + sources[label] = s_path_obj + + return sources + + +def verify_ufd(dev_path): + """Check that dev_path is a valid UFD, returns pathlib.Path obj.""" + ufd_dev = None + + try: + ufd_dev = find_path(dev_path) + except FileNotFoundError: + print_error('ERROR: UFD device not found: {}'.format( + args['--ufd-device'])) + abort(False) + + if not is_valid_path(ufd_dev, 'UFD'): + print_error('ERROR: Invalid UFD device: {}'.format(ufd_dev)) + abort(False) + + return ufd_dev + + if __name__ == '__main__': print("This file is not meant to be called directly.") From 72cc33cb7ed75a61bdb27b05d5cce271d82863ed Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 18:48:54 -0700 Subject: [PATCH 37/75] Only show destination device, not all devices --- .bin/Scripts/functions/ufd.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 7c7a9b48..7753d88a 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -200,12 +200,14 @@ def show_selections(args, sources, ufd_dev, ufd_sources): cmd = [ 'lsblk', '--nodeps', '--noheadings', '--output', 'NAME,TRAN,SIZE,VENDOR,MODEL,SERIAL', + ufd_dev, ] result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') print_standard(result.stdout.strip()) cmd = [ 'lsblk', '--noheadings', '--output', 'NAME,SIZE,FSTYPE,LABEL,MOUNTPOINT', + ufd_dev, ] result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') for line in result.stdout.splitlines()[1:]: @@ -246,8 +248,7 @@ def verify_ufd(dev_path): try: ufd_dev = find_path(dev_path) except FileNotFoundError: - print_error('ERROR: UFD device not found: {}'.format( - args['--ufd-device'])) + print_error('ERROR: UFD device not found: {}'.format(dev_path)) abort(False) if not is_valid_path(ufd_dev, 'UFD'): From e098d40c2fb1d06bd9712ca317e756ac0d72f061 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Sun, 14 Apr 2019 18:49:32 -0700 Subject: [PATCH 38/75] Added pylint exceptions --- .bin/Scripts/build-ufd | 13 +++++++------ .bin/Scripts/functions/ufd.py | 6 +++--- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 887932a7..72967920 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -1,6 +1,8 @@ #!/bin/env python3 # -## Wizard Kit: UFD build tool +# pylint: disable=no-name-in-module,wildcard-import +# vim: sts=2 sw=2 ts=2 +"""Wizard Kit: UFD build tool""" import os import sys @@ -15,12 +17,13 @@ init_global_vars(silent=True) # Main section if __name__ == '__main__': + # pylint: disable=invalid-name # Set log try: global_vars['LogDir'] = '{}/Logs'.format( get_user_home(get_user_name())) set_log_file('Build UFD ({Date-Time}).log'.format(**global_vars)) - except: + except: # pylint: disable=bare-except major_exception() # Header @@ -39,7 +42,7 @@ if __name__ == '__main__': except SystemExit as sys_exit: # Catch docopt exits exit_script(sys_exit.code) - except: + except: # pylint: disable=bare-except major_exception() try: @@ -74,7 +77,5 @@ if __name__ == '__main__': exit_script() except SystemExit as sys_exit: exit_script(sys_exit.code) - except: + except: # pylint: disable=bare-except major_exception() - -# vim: sts=2 sw=2 ts=2 diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 7753d88a..1d9d9970 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -1,4 +1,6 @@ -# Wizard Kit: Functions - UFD +"""Wizard Kit: Functions - UFD""" +# pylint: disable=broad-except,wildcard-import +# vim: sts=2 sw=2 ts=2 import os import re @@ -260,5 +262,3 @@ def verify_ufd(dev_path): if __name__ == '__main__': print("This file is not meant to be called directly.") - -# vim: sts=2 sw=2 ts=2 From 2230ea1eeab4634155b6dde5983c0e6e49a69ceb Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 20:30:39 -0700 Subject: [PATCH 39/75] Added prep_device() * Skipped if --update is used --- .bin/Scripts/build-ufd | 4 +-- .bin/Scripts/functions/ufd.py | 53 +++++++++++++++++++++++++++++++++++ 2 files changed, 55 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 72967920..1b29b91b 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -56,9 +56,9 @@ if __name__ == '__main__': print_success("It's go-time!") exit_script() - # Double-check if formating device - # Format and partition device + if not args['--update']: + prep_device(ufd_dev, UFD_LABEL, use_mbr=args['--use-mbr']) # Copy sources diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 1d9d9970..902d3b14 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -125,6 +125,59 @@ def is_valid_path(path_obj, path_type): return valid_path +def prep_device(dev_path, label, use_mbr=False): + """Format device in preparation for applying the WizardKit components + + This is done is four steps: + 1. Zero-out first 64MB (this deletes the partition table and/or bootloader) + 2. Create a new partition table (GPT by default, optionally MBR) + 3. Set boot flag + 4. Format partition (FAT32, 4K aligned) + """ + # Zero-out first 64MB + cmd = 'dd bs=4M count=16 if=/dev/zero of={}'.format(dev_path).split() + try_and_print( + message='Zeroing first 64MB...', + function=run_program, + cmd=cmd, + ) + + # Create partition table + cmd = 'parted {} --script -- mklabel {} primary fat32 4MiB {}'.format( + dev_path, + 'msdos' if use_mbr else 'gpt', + '-1s' if use_mbr else '-4MiB', + ).split() + try_and_print( + message='Creating partition table...', + function=run_program, + cmd=cmd, + ) + + # Set boot flag + cmd = 'parted {} set 1 {} on'.format( + dev_path, + 'boot' if use_mbr else 'legacy_boot', + ).split() + try_and_print( + message='Setting boot flag...', + function=run_program, + cmd=cmd, + ) + + # Format partition + cmd = [ + 'mkfs.vfat', '-F', '32', + '-n', label, + '{}1'.format(dev_path), + ] + try_and_print( + message='Formatting partition...', + function=run_program, + cmd=cmd, + ) + + def recursive_copy(source, dest, overwrite=True): """Copy source to dest recursively. From c8944e5a14b6beb87aa722b1a30a05867ff2f2af Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 21:27:27 -0700 Subject: [PATCH 40/75] Fixed prep_device() --- .bin/Scripts/build-ufd | 8 ++++---- .bin/Scripts/functions/ufd.py | 16 ++++++++++++++-- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 1b29b91b..3c0abbe6 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -52,14 +52,14 @@ if __name__ == '__main__': show_selections(args, sources, ufd_dev, UFD_SOURCES) confirm_selections(args) - # TODO: DELETEME - print_success("It's go-time!") - exit_script() - # Format and partition device if not args['--update']: prep_device(ufd_dev, UFD_LABEL, use_mbr=args['--use-mbr']) + # TODO: DELETEME + print_success("It's go-time!") + exit_script() + # Copy sources # Update boot entries diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 902d3b14..34940e1f 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -143,7 +143,7 @@ def prep_device(dev_path, label, use_mbr=False): ) # Create partition table - cmd = 'parted {} --script -- mklabel {} primary fat32 4MiB {}'.format( + cmd = 'parted {} --script -- mklabel {} mkpart primary fat32 4MiB {}'.format( dev_path, 'msdos' if use_mbr else 'gpt', '-1s' if use_mbr else '-4MiB', @@ -165,11 +165,23 @@ def prep_device(dev_path, label, use_mbr=False): cmd=cmd, ) + # Find partition + cmd = [ + 'lsblk', + '--list', + '--noheadings', + '--output', 'name', + '--paths', + dev_path, + ] + result = run_program(cmd, encoding='utf-8', errors='ignore') + part_path = result.stdout.splitlines()[-1].strip() + # Format partition cmd = [ 'mkfs.vfat', '-F', '32', '-n', label, - '{}1'.format(dev_path), + part_path, ] try_and_print( message='Formatting partition...', From af757c5582514c5ee02a7395b9ce14a598b4cfff Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 21:28:53 -0700 Subject: [PATCH 41/75] Show full device paths --- .bin/Scripts/functions/ufd.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 34940e1f..93e0644c 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -265,14 +265,14 @@ def show_selections(args, sources, ufd_dev, ufd_sources): # Destination print_info('Destination') cmd = [ - 'lsblk', '--nodeps', '--noheadings', - '--output', 'NAME,TRAN,SIZE,VENDOR,MODEL,SERIAL', + 'lsblk', '--nodeps', '--noheadings', '--paths', + '--output', 'NAME,FSTYPE,TRAN,SIZE,VENDOR,MODEL,SERIAL', ufd_dev, ] result = run_program(cmd, check=False, encoding='utf-8', errors='ignore') print_standard(result.stdout.strip()) cmd = [ - 'lsblk', '--noheadings', + 'lsblk', '--noheadings', '--paths', '--output', 'NAME,SIZE,FSTYPE,LABEL,MOUNTPOINT', ufd_dev, ] From 807c94e2cef8d3207b57571183c49f2d5b91e433 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 21:29:10 -0700 Subject: [PATCH 42/75] Add argument for Linux (dGPU) --- .bin/Scripts/settings/ufd.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index 13ecd4e9..c754d2b9 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -18,6 +18,7 @@ Usage: Options: -e PATH, --extra-dir PATH + -g PATH, --linux-dgpu PATH -k PATH, --main-kit PATH -l PATH, --linux PATH -m PATH, --linux-minimal PATH @@ -35,6 +36,7 @@ ISO_LABEL = '{}_LINUX'.format(KIT_NAME_SHORT) UFD_LABEL = '{}_UFD'.format(KIT_NAME_SHORT) UFD_SOURCES = OrderedDict({ 'Linux': {'Arg': '--linux', 'Type': 'ISO'}, + 'Linux (dGPU)': {'Arg': '--linux-dgpu', 'Type': 'ISO'}, 'Linux (Minimal)': {'Arg': '--linux-minimal', 'Type': 'ISO'}, 'WinPE': {'Arg': '--winpe', 'Type': 'ISO'}, 'Main Kit': {'Arg': '--main-kit', 'Type': 'KIT'}, From 996b01bb340aafcc91684d7ea577c6d98935c175 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 21:30:44 -0700 Subject: [PATCH 43/75] Add Linux dGPU items --- .bin/Scripts/settings/ufd.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index c754d2b9..2aa9b5e2 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -63,6 +63,12 @@ ITEMS = { ('/EFI/boot', '/EFI/'), ('/EFI/memtest86', '/EFI/'), ), + 'Linux (dGPU)': ( + ('/arch/boot/archiso.img', '/dgpu/'), + ('/arch/boot/vmlinuz', '/dgpu/'), + ('/arch/pkglist.x86_64.txt', '/dgpu/'), + ('/arch/x86_64', '/dgpu/'), + ), 'Linux (Minimal)': ( ('/arch/boot/archiso.img', '/arch_minimal/'), ('/arch/boot/vmlinuz', '/arch_minimal/'), From d769b1ad4ee79c9894cc20985b413cf4dbe05004 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 22:05:48 -0700 Subject: [PATCH 44/75] Set overwrite=False by default --- .bin/Scripts/functions/ufd.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 93e0644c..06bb3e45 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -190,7 +190,7 @@ def prep_device(dev_path, label, use_mbr=False): ) -def recursive_copy(source, dest, overwrite=True): +def recursive_copy(source, dest, overwrite=False): """Copy source to dest recursively. NOTE: This uses rsync style source/dest syntax. From 7ee04060d80d7176cae7a66e08f77ce4821d9481 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 22:37:58 -0700 Subject: [PATCH 45/75] Added dGPU to BOOT_ENTRIES --- .bin/Scripts/settings/ufd.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index 2aa9b5e2..b09f84fe 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -46,7 +46,8 @@ UFD_SOURCES = OrderedDict({ # Definitions: Boot entries ## NOTE: if key path exists uncomment #value# lines BOOT_ENTRIES = { - 'arch_minimal': 'MINIMAL', + 'arch_minimal': 'MINIMAL', + 'dgpu': 'DGPU', 'sources/boot.wim': 'WINPE', } From 26aca0df9f87d8d5a6ffbb23e69cb661c85dfccb Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 22:38:54 -0700 Subject: [PATCH 46/75] Added mount and unmount sections --- .bin/Scripts/build-ufd | 12 +++++++----- .bin/Scripts/functions/ufd.py | 13 +++++++++++++ 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 3c0abbe6..7571eae3 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -56,9 +56,13 @@ if __name__ == '__main__': if not args['--update']: prep_device(ufd_dev, UFD_LABEL, use_mbr=args['--use-mbr']) - # TODO: DELETEME - print_success("It's go-time!") - exit_script() + # Mount UFD + try_and_print( + message='Mounting UFD...', + function=mount, + mount_source=ufd_dev, + mount_point='/mnt/UFD', + ) # Copy sources @@ -68,8 +72,6 @@ if __name__ == '__main__': # Hide items - # Unmount sources - # Done if not args['--force']: print_standard('\nDone.') diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 06bb3e45..96ce2d0a 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -125,6 +125,19 @@ def is_valid_path(path_obj, path_type): return valid_path +def mount(mount_source, mount_point): + """Mount mount_source on mount_point.""" + os.makedirs(mount_point, exist_ok=True) + cmd = ['mount', mount_source, mount_point] + run_program(cmd) + + +def unmount(mount_point): + """Unmount mount_point.""" + cmd = ['umount', mount_point] + run_program(cmd) + + def prep_device(dev_path, label, use_mbr=False): """Format device in preparation for applying the WizardKit components From fc9de6126996556c4cf672e29f0d1905466802dd Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 22:40:20 -0700 Subject: [PATCH 47/75] Added copy_source() --- .bin/Scripts/build-ufd | 8 ++++++++ .bin/Scripts/functions/ufd.py | 11 +++++++++++ 2 files changed, 19 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 7571eae3..fbe1bdff 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -65,6 +65,14 @@ if __name__ == '__main__': ) # Copy sources + for s_label, s_path in sources.items(): + try_and_print( + message='Copying {} files...'.format(s_label), + function=copy_source, + source=s_path, + items=ITEMS[s_label], + overwrite=True, + ) # Update boot entries diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 96ce2d0a..344c273d 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -58,6 +58,17 @@ def confirm_selections(args): print_standard(' ') +def copy_source(source, items, overwrite=False): + """Mount source and copy items to /mnt/UFD.""" + os.makedirs('/mnt/Source', exist_ok=True) + mount(source, '/mnt/Source') + for i_source, i_dest in items: + i_source = '/mnt/Source{}'.format(i_source) + i_dest = '/mnt/UFD{}'.format(i_dest) + recursive_copy(i_source, i_dest, overwrite=overwrite) + unmount('/mnt/Source') + + def find_path(path): """Find path case-insensitively, returns pathlib.Path obj.""" path_obj = pathlib.Path(path).resolve() From 95f4877862e8edcc63895820bfed4a9992dccb2f Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:04:37 -0700 Subject: [PATCH 48/75] Reordered functions --- .bin/Scripts/functions/ufd.py | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 344c273d..9a17ea64 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -60,7 +60,6 @@ def confirm_selections(args): def copy_source(source, items, overwrite=False): """Mount source and copy items to /mnt/UFD.""" - os.makedirs('/mnt/Source', exist_ok=True) mount(source, '/mnt/Source') for i_source, i_dest in items: i_source = '/mnt/Source{}'.format(i_source) @@ -143,12 +142,6 @@ def mount(mount_source, mount_point): run_program(cmd) -def unmount(mount_point): - """Unmount mount_point.""" - cmd = ['umount', mount_point] - run_program(cmd) - - def prep_device(dev_path, label, use_mbr=False): """Format device in preparation for applying the WizardKit components @@ -312,6 +305,12 @@ def show_selections(args, sources, ufd_dev, ufd_sources): print_standard(' ') +def unmount(mount_point): + """Unmount mount_point.""" + cmd = ['umount', mount_point] + run_program(cmd) + + def verify_sources(args, ufd_sources): """Check all sources and abort if necessary, returns dict.""" sources = OrderedDict() From c16e97e49a4f72dffcec2138137abbe38deaf3fa Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:07:33 -0700 Subject: [PATCH 49/75] Added boot entry sections --- .bin/Scripts/build-ufd | 6 ++++++ .bin/Scripts/functions/ufd.py | 29 +++++++++++++++++++++++++++++ .bin/Scripts/settings/ufd.py | 13 +++++++++---- 3 files changed, 44 insertions(+), 4 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index fbe1bdff..e21d876c 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -75,6 +75,12 @@ if __name__ == '__main__': ) # Update boot entries + try_and_print( + message='Enabling boot entries...', + function=enable_boot_entries, + boot_entries=BOOT_ENTRIES, + boot_files=BOOT_FILES, + ) # Install syslinux diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 9a17ea64..dbce5bb6 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -68,6 +68,35 @@ def copy_source(source, items, overwrite=False): unmount('/mnt/Source') +def enable_boot_entries(boot_entries, boot_files): + """Enable boot entries if related paths exist.""" + configs = [] + + # Find config files + for c_path, c_ext in boot_files.items(): + c_path = find_path(c_path) + for item in os.scandir(c_path): + if item.name.lower().endswith(c_ext.lower()): + configs.append(item.path) + + # Uncomment found entries + for b_path, b_comment in boot_entries: + try: + find_path('/mnt/UFD{}'.format(b_path)) + except (FileNotFoundError, NotADirectoryError): + # Entry not found, continue to next entry + continue + + # Update config files + cmd = [ + 'sed', + '--in-place', + '"s/#{}#//"'.format(b_comment), + *configs, + ] + run_program(cmd) + + def find_path(path): """Find path case-insensitively, returns pathlib.Path obj.""" path_obj = pathlib.Path(path).resolve() diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index b09f84fe..dc7693c4 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -44,11 +44,16 @@ UFD_SOURCES = OrderedDict({ }) # Definitions: Boot entries -## NOTE: if key path exists uncomment #value# lines BOOT_ENTRIES = { - 'arch_minimal': 'MINIMAL', - 'dgpu': 'DGPU', - 'sources/boot.wim': 'WINPE', + # Path to check: Comment to remove + '/arch_minimal': 'UFD-MINIMAL', + '/dgpu': 'UFD-DGPU', + '/sources/boot.wim': 'UFD-WINPE', + } +BOOT_FILES = { + # Directory: extension + '/arch/boot/syslinux': 'cfg', + '/EFI/boot': 'conf', } # Definitions: Sources and Destinations From c66b2facbf37bafc00f801f2c7e93133f70d0a1b Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:12:27 -0700 Subject: [PATCH 50/75] Skip confirm_selections if --force is used --- .bin/Scripts/build-ufd | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index e21d876c..4ad726e1 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -50,7 +50,8 @@ if __name__ == '__main__': ufd_dev = verify_ufd(args['--ufd-device']) sources = verify_sources(args, UFD_SOURCES) show_selections(args, sources, ufd_dev, UFD_SOURCES) - confirm_selections(args) + if not args['--force']: + confirm_selections(args) # Format and partition device if not args['--update']: From 4115f3cfe178648b5e4f637d204e04c50d4309b2 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:16:57 -0700 Subject: [PATCH 51/75] Removed unused args --- .bin/Scripts/settings/ufd.py | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index dc7693c4..5123a8a1 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -17,17 +17,15 @@ Usage: build-ufd (-h | --help) Options: + -d PATH, --linux-dgpu PATH -e PATH, --extra-dir PATH - -g PATH, --linux-dgpu PATH -k PATH, --main-kit PATH -l PATH, --linux PATH -m PATH, --linux-minimal PATH -u PATH, --ufd-device PATH -w PATH, --winpe PATH - -d --debug Enable debug mode -h --help Show this page - -v --verbose Enable verbose mode -M --use-mbr Use real MBR instead of GPT w/ Protective MBR -F --force Bypass all confirmation messages. USE WITH EXTREME CAUTION! -U --update Don't format device, just update From 89ac824d828a7adf7f4c90bda0d10c27201cf795 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:44:42 -0700 Subject: [PATCH 52/75] Expanded boot entries sections * Update Arch labels from ISO_LABEL to UFD_LABEL * Added Linux (Minimal) to syslinux * Added Linux (Minimal) and Linux (dGPU) entries to rEFInd * Removed Linux (i3) entries * I guess this is a hidden feature now... --- .bin/Scripts/build-ufd | 6 +++-- .bin/Scripts/functions/ufd.py | 18 ++++++++++--- .linux_items/include/EFI/boot/icons/dgpu.png | Bin 0 -> 3086 bytes .linux_items/include/EFI/boot/refind.conf | 23 +++++++++++++--- .../include/syslinux/wk_sys_linux.cfg | 25 +++++++++--------- 5 files changed, 50 insertions(+), 22 deletions(-) create mode 100644 .linux_items/include/EFI/boot/icons/dgpu.png diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 4ad726e1..646d96dd 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -77,10 +77,12 @@ if __name__ == '__main__': # Update boot entries try_and_print( - message='Enabling boot entries...', - function=enable_boot_entries, + message='Updating boot entries...', + function=update_boot_entries, boot_entries=BOOT_ENTRIES, boot_files=BOOT_FILES, + iso_label=ISO_LABEL, + ufd_label=UFD_LABEL, ) # Install syslinux diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index dbce5bb6..f6083da0 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -68,8 +68,8 @@ def copy_source(source, items, overwrite=False): unmount('/mnt/Source') -def enable_boot_entries(boot_entries, boot_files): - """Enable boot entries if related paths exist.""" +def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): + """Update boot files for UFD usage""" configs = [] # Find config files @@ -79,7 +79,17 @@ def enable_boot_entries(boot_entries, boot_files): if item.name.lower().endswith(c_ext.lower()): configs.append(item.path) - # Uncomment found entries + # Update Linux labels + cmd = [ + 'sed', + '--in-place', + '--regexp-extended', + 's/{}/{}/'.format(iso_label, ufd_label), + *configs, + ] + run_program(cmd) + + # Uncomment extra entries if present for b_path, b_comment in boot_entries: try: find_path('/mnt/UFD{}'.format(b_path)) @@ -87,7 +97,7 @@ def enable_boot_entries(boot_entries, boot_files): # Entry not found, continue to next entry continue - # Update config files + # Entry found, update config files cmd = [ 'sed', '--in-place', diff --git a/.linux_items/include/EFI/boot/icons/dgpu.png b/.linux_items/include/EFI/boot/icons/dgpu.png new file mode 100644 index 0000000000000000000000000000000000000000..e9770abd1ba2487b1e3d08e9a643004f94d019c3 GIT binary patch literal 3086 zcmV+p4Ds`cP)Tvy7{wCK`mp%wa=cJ5>U=$&R3OXpGM z&Y8LAo7|+G%$>*nxBwb z4BQ{8JP-;11=u3fGGVnf$j6AY0JjCm05D&s+Kt+$ewm&ekjOF4Y_FfA=D zBHiK;kZolF+T~0R6#=CA!3pMevuxQicI?=}qD6}^O%p{?Fin#mfBaE6MngpacL?)k zi(eo?6otaVLdwd@n3$MAQIzS=gW(Xgh0wJ8G$V}w5&+=(>#wJ#riS$NbS5V!|IhSb zUA%ZvQ~-=fBS1J+L`Uf9r=Mocnl+ea=suUTXU`^HmL@H}ysE0I$j!|S%Y1;7Cr=8S zgGm4)kjLX;-@bk1l6#XP|YeZoJ#;{kZ+p@$+q z=iIq-l$4Yt#q&EJfWpGUh`v8OJj}xnKb$nr?`QxrGBWV_d|_AjdU|@;ym@nS)qtD~ zz`S|$!v1bULjzS+RmoQcb}|4Sk0<0?-{0R)MMVXjot;UU295^c(q`X4zrV-hp|`h} z{rmUR)YO#JY2au8d_Et#uH*On(KLYP-%jc;~%`_cBYW9+} zs$!aE*dvE*)*k>Jm>|MIp+aiy+O@1$v4UG}xrMZ}wCN^Xzu(WVzy3;ldpnJdjp(`_ zlk4Am@4XZi6>;sg*Wz}&al75PTrLd5z%UGST}RV2Mn^|!Yir}cfddQ=56cJ;td(Y2tFZICbh2pMU;2 zpMLsj*ypZVwThymB37iRR?%eUWtOLcWM-QC?1fSKg=dU@=z$5^vw%@zG! z(=_pVy&O1jfVQ@_8LM@R7A@kAJMLi9rcHP}o;jO7+r2b5H&aiju1R$W>Zo7?& ziVFOGe@w4qnkH#!X&gOzl>YvH($mwq{r1~uob40KdjQzJeLFopJraPOJ9n~i<3?K& zU$h!Td3ibQ?d{G5prWFJB}ebTuAnCf!d+)uM`~YNU zXR~|vZbygxnbh6g%>xfSko*9=^2#eQYpP9DwYIjhbLUPpO|$j7w)X|BU%#G(3l~bq zgYy2my1KYcF0s8Dc<9ifkOMKCWPWXJEp>HuvAm2p)xgc0H;cNCPF&2dudk1_`C^p; z)~#D73w}WbzM7hvxZj6u0OaTAla-YvooA|xc=ztzLfngO06hBWqfyPkNk+Z)+G~uA zj5rH`8*jW(hJRpUVuCNe_(GWbu?2v6^X75&)mO_`A9&-9H-w6Wwg9kU!v@*#1B{Q4 z$Fkd3TmaUuUoWeDrfKIeFmV7-Rh5j4495eYC<^bt|GqN;aJgKL2f#24A=eU&IRGw~ zE2`yJl1&2x147IB`O{Z|R5#aRFxJ$h6+A5<22^2sNi1wda!olRwBr85Bd;DZljIba3|^7Hd~_uY5nRx_{-fZu-mjlsb|>G}*1+;GDUG&VMp zlarIY004ad{r55(xC{g?my6okT8fK{Z5>5zD*%TM9g=Q`0Ab6PEi^SXv2x|gU_9$BrG7i$>0%ufP7<)|td{1HkY1vuDp9>G&mYzujpP*OeO%A3iL{ z3kK<%Z@#g8{lK^{-SN^(FG=SCP1EACdT87M`0A^#=r+_S-^adBSZUA9y<&8X8DVO-)Jwe*XDqwr<^O*X0st`}km`rl!)^ z*qC(7%xap(#*G{8+#fJ;$^gNdn3!PKu3bq5fN7d++O)~`%^?%23=pjD?rzG<%VRd7 z#5BzrkC^1Oio%W^JA~OQXga$U{jF(lZ%0uS%F4>-{N|XZNlHozr%s)sv$K;kXU_1; zFTYH$C>l$OW)bb04WwALLj?j$r4_D z^;O(%cSMGmrishtqNk^a=H_NT`Q($Zm#oRm%%r%um^<&hGpaR@P19s>aF8dSc!K`^ z{&*$b9{>%QjIa(=>cOA9Zzg?BBotieKC7^|EW%E(!_?@OV6^s*0+r)4=)tewv$`*}HeI2uXDj z$g#}#M*;vA09OI^K%t1`165T?PfsT+D+`~`$Kc=~nx@&ZE}^0*(}&ybM%Q%=!-#1? zG77Z<{{TiU03s>`2A<+$Q2{UvgOQPuxRk7ejTU$rypJ#Ol1L(e3V5yX-vKN{Dv@*+ z_zQ3W7zd0<+W|}~Y-qrCnVt!!?UsN3*&;xw7M8$?=Ycc8UuC)`g#HP%SXKDRxd4C_ zI!vGkI1UtuRx6O2RzI)}IAYZRe3uLT;gkV_zvB)n4`c%O14Tf-gh7a^-oJr^K!X*n zFIxG&Hrv}DE&ze=xtQu9^jgPN){%nXeF{k|!wT`E*5L!jnCkh{Lzy250DL};3{{R3007*qoM6N<$f`+B;Bme*a literal 0 HcmV?d00001 diff --git a/.linux_items/include/EFI/boot/refind.conf b/.linux_items/include/EFI/boot/refind.conf index 4ab3be7b..62a639f7 100644 --- a/.linux_items/include/EFI/boot/refind.conf +++ b/.linux_items/include/EFI/boot/refind.conf @@ -26,15 +26,30 @@ menuentry "Linux" { initrd /arch/boot/amd_ucode.img initrd /arch/boot/x86_64/archiso.img options "archisobasedir=arch archisolabel=%ARCHISO_LABEL% copytoram loglevel=3" - submenuentry "Linux (i3)" { - add_options "i3" - } submenuentry "Linux (CLI)" { - add_options "loglevel=4 nomodeset nox" + add_options "nox" } + #UFD-MINIMAL#submenuentry "Linux (Minimal)" { + #UFD-MINIMAL# loader /arch_minimal/vmlinuz + #UFD-MINIMAL# initrd + #UFD-MINIMAL# initrd /arch/boot/intel_ucode.img + #UFD-MINIMAL# initrd /arch/boot/amd_ucode.img + #UFD-MINIMAL# initrd /arch_minimal/archiso.img + #UFD-MINIMAL# options + #UFD-MINIMAL# options "archisobasedir=arch_minimal archisolabel=%ARCHISO_LABEL% copytoram loglevel=3" + #UFD-MINIMAL#} } #UFD-WINPE#menuentry "WindowsPE" { #UFD-WINPE# ostype windows #UFD-WINPE# icon /EFI/boot/icons/wk_win.png #UFD-WINPE# loader /EFI/microsoft/bootx64.efi #UFD-WINPE#} +#UFD-DGPU#menuentry "Mac dGPU Disable Tool" { +#UFD-DGPU# icon /EFI/boot/icons/dgpu.png +#UFD-DGPU# loader /dgpu/vmlinuz +#UFD-DGPU# initrd /arch/boot/intel_ucode.img +#UFD-DGPU# initrd /arch/boot/amd_ucode.img +#UFD-DGPU# initrd /dgpu/archiso.img +#UFD-DGPU# options "archisobasedir=dgpu archisolabel=%ARCHISO_LABEL% nomodeset" +#UFD-DGPU#} + diff --git a/.linux_items/include/syslinux/wk_sys_linux.cfg b/.linux_items/include/syslinux/wk_sys_linux.cfg index d4319c00..b6a9370c 100644 --- a/.linux_items/include/syslinux/wk_sys_linux.cfg +++ b/.linux_items/include/syslinux/wk_sys_linux.cfg @@ -8,17 +8,6 @@ LINUX boot/x86_64/vmlinuz INITRD boot/intel_ucode.img,boot/amd_ucode.img,boot/x86_64/archiso.img APPEND archisobasedir=%INSTALL_DIR% archisolabel=%ARCHISO_LABEL% copytoram loglevel=3 -LABEL wk_linux_i3 -TEXT HELP -A live Linux environment (i3) - * HW diagnostics, file-based backups, data recovery, etc -ENDTEXT -MENU LABEL Linux (i3) -LINUX boot/x86_64/vmlinuz -INITRD boot/intel_ucode.img,boot/amd_ucode.img,boot/x86_64/archiso.img -APPEND archisobasedir=%INSTALL_DIR% archisolabel=%ARCHISO_LABEL% copytoram loglevel=3 i3 -SYSAPPEND 3 - LABEL wk_linux_cli TEXT HELP A live Linux environment (CLI) @@ -27,5 +16,17 @@ ENDTEXT MENU LABEL Linux (CLI) LINUX boot/x86_64/vmlinuz INITRD boot/intel_ucode.img,boot/amd_ucode.img,boot/x86_64/archiso.img -APPEND archisobasedir=%INSTALL_DIR% archisolabel=%ARCHISO_LABEL% copytoram nox nomodeset +APPEND archisobasedir=%INSTALL_DIR% archisolabel=%ARCHISO_LABEL% copytoram nox SYSAPPEND 3 + +#UFD-MINIMAL#LABEL wk_linux_minimal +#UFD-MINIMAL#TEXT HELP +#UFD-MINIMAL#A live Linux environment (Minimal) +#UFD-MINIMAL# * HW diagnostics, file-based backups, data recovery, etc +#UFD-MINIMAL#ENDTEXT +#UFD-MINIMAL#MENU LABEL Linux (Minimal) +#UFD-MINIMAL#LINUX ../arch_minimal/vmlinuz +#UFD-MINIMAL#INITRD boot/intel_ucode.img,boot/amd_ucode.img,../arch_minimal/archiso.img +#UFD-MINIMAL#APPEND archisobasedir=arch_minimal archisolabel=%ARCHISO_LABEL% copytoram loglevel=3 +#UFD-MINIMAL#SYSAPPEND 3 + From 091c31d33ac28d2ab6a31e5b99168bc6cea595ab Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:52:06 -0700 Subject: [PATCH 53/75] Bugfix --- .bin/Scripts/functions/setup.py | 10 ---------- .bin/Scripts/new_system_setup.py | 2 -- 2 files changed, 12 deletions(-) diff --git a/.bin/Scripts/functions/setup.py b/.bin/Scripts/functions/setup.py index dc6c53a4..05a9dca3 100644 --- a/.bin/Scripts/functions/setup.py +++ b/.bin/Scripts/functions/setup.py @@ -73,16 +73,6 @@ def config_windows_updates(): write_registry_settings(SETTINGS_WINDOWS_UPDATES, all_users=True) -def disable_windows_telemetry(): - """Disable Windows 10 telemetry settings with O&O ShutUp10.""" - extract_item('ShutUp10', silent=True) - cmd = [ - r'{BinDir}\ShutUp10\OOSU10.exe'.format(**global_vars), - r'{BinDir}\ShutUp10\1201.cfg'.format(**global_vars), - '/quiet'] - run_program(cmd) - - def update_clock(): """Set Timezone and sync clock.""" run_program(['tzutil' ,'/s', WINDOWS_TIME_ZONE], check=False) diff --git a/.bin/Scripts/new_system_setup.py b/.bin/Scripts/new_system_setup.py index 1f6cfcd0..9cc93142 100644 --- a/.bin/Scripts/new_system_setup.py +++ b/.bin/Scripts/new_system_setup.py @@ -100,8 +100,6 @@ if __name__ == '__main__': if global_vars['OS']['Version'] == '10': try_and_print(message='Explorer (system)...', function=config_explorer_system, cs='Done') - try_and_print(message='Disabling telemetry...', - function=disable_windows_telemetry, cs='Done') try_and_print(message='Windows Updates...', function=config_windows_updates, cs='Done') try_and_print(message='Updating Clock...', From 9652aa4623565503134ea2f3c238625a3aa43a0a Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Mon, 15 Apr 2019 23:57:46 -0700 Subject: [PATCH 54/75] Added install Syslinux section --- .bin/Scripts/build-ufd | 6 ++++++ .bin/Scripts/functions/ufd.py | 14 ++++++++++++++ 2 files changed, 20 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 646d96dd..1fbb1f46 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -86,6 +86,12 @@ if __name__ == '__main__': ) # Install syslinux + try_and_print( + message='Installing Syslinux...', + function=install_syslinux, + ufd_dev=ufd_dev, + use_mbr=args['--use-mbr'], + ) # Hide items diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index f6083da0..5b289a73 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -159,6 +159,20 @@ def get_user_name(): return user +def install_syslinux(ufd_dev, use_mbr): + """Install Syslinux to UFD.""" + cmd = [ + 'dd', + 'bs=440', + 'count=1', + 'if=/usr/lib/syslinux/bios/{}.bin'.format( + 'mbr' if use_mbr else 'gptmbr', + ), + 'of={}'.format(ufd_dev), + ] + run_program(cmd) + + def is_valid_path(path_obj, path_type): """Verify path_obj is valid by type, returns bool.""" valid_path = False From 4215a2fd78103a5a3e6c36b8a1bda8959cf26f5e Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Tue, 16 Apr 2019 00:14:46 -0700 Subject: [PATCH 55/75] Added find_first_partition() --- .bin/Scripts/functions/ufd.py | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 5b289a73..274b50c1 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -107,6 +107,22 @@ def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): run_program(cmd) +def find_first_partition(dev_path): + """Find path to first partition of dev, returns str.""" + cmd = [ + 'lsblk', + '--list', + '--noheadings', + '--output', 'name', + '--paths', + dev_path, + ] + result = run_program(cmd, encoding='utf-8', errors='ignore') + part_path = result.stdout.splitlines()[-1].strip() + + return part_path + + def find_path(path): """Find path case-insensitively, returns pathlib.Path obj.""" path_obj = pathlib.Path(path).resolve() @@ -235,23 +251,11 @@ def prep_device(dev_path, label, use_mbr=False): cmd=cmd, ) - # Find partition - cmd = [ - 'lsblk', - '--list', - '--noheadings', - '--output', 'name', - '--paths', - dev_path, - ] - result = run_program(cmd, encoding='utf-8', errors='ignore') - part_path = result.stdout.splitlines()[-1].strip() - # Format partition cmd = [ 'mkfs.vfat', '-F', '32', '-n', label, - part_path, + find_first_partition(dev_path), ] try_and_print( message='Formatting partition...', From a9461311bc97075d083160d5bf1bccc669483330 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Tue, 16 Apr 2019 00:15:33 -0700 Subject: [PATCH 56/75] Unmount UFD before installing Syslinux --- .bin/Scripts/build-ufd | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 1fbb1f46..27f0b1af 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -85,6 +85,13 @@ if __name__ == '__main__': ufd_label=UFD_LABEL, ) + # Unmount UFD + try_and_print( + message='Unmounting UFD...', + function=mount, + mount_point='/mnt/UFD', + ) + # Install syslinux try_and_print( message='Installing Syslinux...', From 949efa4de60d604222944ac4394a63099a40a5c0 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Tue, 16 Apr 2019 00:16:05 -0700 Subject: [PATCH 57/75] Added hide items sections --- .bin/Scripts/build-ufd | 6 ++++++ .bin/Scripts/functions/ufd.py | 14 ++++++++++++++ .bin/Scripts/settings/ufd.py | 15 +++++++++++++++ 3 files changed, 35 insertions(+) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 27f0b1af..21363677 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -101,6 +101,12 @@ if __name__ == '__main__': ) # Hide items + try_and_print( + message='Hiding items...', + function=hide_items, + ufd_dev=ufd_dev, + items=ITEMS_HIDDEN, + ) # Done if not args['--force']: diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 274b50c1..de4994cb 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -175,6 +175,20 @@ def get_user_name(): return user +def hide_items(ufd_dev, items): + """Set FAT32 hidden flag for items.""" + # pylint: disable=invalid-name + with open('/root/.mtoolsrc', 'w') as f: + f.write('drive U: file="{}"\n'.format( + find_first_partition(ufd_dev))) + f.write('mtools_skip_check=1\n') + + # Hide items + for item in items: + cmd = ['yes | mattrib +h "U:/{}"'.format(item)] + run_program(cmd, check=False, shell=True) + + def install_syslinux(ufd_dev, use_mbr): """Install Syslinux to UFD.""" cmd = [ diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index 5123a8a1..db4a2127 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -95,6 +95,21 @@ ITEMS = { ('/sources/boot.wim', '/sources/'), ), } +ITEMS_HIDDEN = ( + # Linux (all versions) + 'arch', + 'arch_minimal', + 'dgpu', + 'EFI', + 'isolinux', + # WinPE + 'boot', + 'bootmgr', + 'bootmgr.efi', + 'en-us', + 'images', + 'sources', + ) if __name__ == '__main__': print("This file is not meant to be called directly.") From cd4ea7586208bb36e7fda7e4ad08a1b2e18767c2 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Tue, 16 Apr 2019 00:23:58 -0700 Subject: [PATCH 58/75] Remove the arch dir when updating the UFD --- .bin/Scripts/build-ufd | 11 +++++++++-- .bin/Scripts/functions/ufd.py | 8 ++++++++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 21363677..2cb06ac1 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -53,8 +53,15 @@ if __name__ == '__main__': if not args['--force']: confirm_selections(args) - # Format and partition device - if not args['--update']: + # Prep UFD + if args['--update']: + # Remove arch folder + try_and_print( + message='Removing Linux...', + function=remove_arch, + ) + else: + # Format and partition prep_device(ufd_dev, UFD_LABEL, use_mbr=args['--use-mbr']) # Mount UFD diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index de4994cb..f771c1da 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -327,6 +327,14 @@ def recursive_copy(source, dest, overwrite=False): raise FileExistsError('Refusing to delete file: {}'.format(dest)) +def remove_arch(): + """Remove arch dir from UFD. + + This ensures a clean installation to the UFD and resets the boot files + """ + shutil.rmtree(find_path('/mnt/UFD/arch')) + + def running_as_root(): """Check if running with effective UID of 0, returns bool.""" return os.geteuid() == 0 From 427243c9339a4c2b461e543a31f300fa73712529 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Tue, 16 Apr 2019 00:33:47 -0700 Subject: [PATCH 59/75] Reordered functions --- .bin/Scripts/functions/ufd.py | 78 +++++++++++++++++------------------ 1 file changed, 39 insertions(+), 39 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index f771c1da..51b1ad7c 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -68,45 +68,6 @@ def copy_source(source, items, overwrite=False): unmount('/mnt/Source') -def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): - """Update boot files for UFD usage""" - configs = [] - - # Find config files - for c_path, c_ext in boot_files.items(): - c_path = find_path(c_path) - for item in os.scandir(c_path): - if item.name.lower().endswith(c_ext.lower()): - configs.append(item.path) - - # Update Linux labels - cmd = [ - 'sed', - '--in-place', - '--regexp-extended', - 's/{}/{}/'.format(iso_label, ufd_label), - *configs, - ] - run_program(cmd) - - # Uncomment extra entries if present - for b_path, b_comment in boot_entries: - try: - find_path('/mnt/UFD{}'.format(b_path)) - except (FileNotFoundError, NotADirectoryError): - # Entry not found, continue to next entry - continue - - # Entry found, update config files - cmd = [ - 'sed', - '--in-place', - '"s/#{}#//"'.format(b_comment), - *configs, - ] - run_program(cmd) - - def find_first_partition(dev_path): """Find path to first partition of dev, returns str.""" cmd = [ @@ -390,6 +351,45 @@ def unmount(mount_point): run_program(cmd) +def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): + """Update boot files for UFD usage""" + configs = [] + + # Find config files + for c_path, c_ext in boot_files.items(): + c_path = find_path(c_path) + for item in os.scandir(c_path): + if item.name.lower().endswith(c_ext.lower()): + configs.append(item.path) + + # Update Linux labels + cmd = [ + 'sed', + '--in-place', + '--regexp-extended', + 's/{}/{}/'.format(iso_label, ufd_label), + *configs, + ] + run_program(cmd) + + # Uncomment extra entries if present + for b_path, b_comment in boot_entries: + try: + find_path('/mnt/UFD{}'.format(b_path)) + except (FileNotFoundError, NotADirectoryError): + # Entry not found, continue to next entry + continue + + # Entry found, update config files + cmd = [ + 'sed', + '--in-place', + '"s/#{}#//"'.format(b_comment), + *configs, + ] + run_program(cmd) + + def verify_sources(args, ufd_sources): """Check all sources and abort if necessary, returns dict.""" sources = OrderedDict() From 21a587ee0f95872e353fd6db70be1bf327faa91c Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 19:24:39 -0700 Subject: [PATCH 60/75] Bugfix sleep() --- .bin/Scripts/functions/common.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/functions/common.py b/.bin/Scripts/functions/common.py index fe75f1ef..28834660 100644 --- a/.bin/Scripts/functions/common.py +++ b/.bin/Scripts/functions/common.py @@ -94,7 +94,7 @@ def abort(show_prompt=True): """Abort script.""" print_warning('Aborted.') if show_prompt: - sleep(timeout) + sleep(1) pause(prompt='Press Enter to exit... ') exit_script(1) From e07c019fb2c422db772b1ced224a87793ebd2d3b Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 19:25:13 -0700 Subject: [PATCH 61/75] Bugfix: Call unmount() not mount() --- .bin/Scripts/build-ufd | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 2cb06ac1..5dd15a7c 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -95,7 +95,7 @@ if __name__ == '__main__': # Unmount UFD try_and_print( message='Unmounting UFD...', - function=mount, + function=unmount, mount_point='/mnt/UFD', ) From 050bef7f85fb7aeb10e2c1407d71bd7f6837b141 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 19:26:28 -0700 Subject: [PATCH 62/75] Skip FileNotFoundError in copy_source() * Avoids crash when copying some WinPE ISOs --- .bin/Scripts/functions/ufd.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 51b1ad7c..1bbe0b53 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -64,7 +64,11 @@ def copy_source(source, items, overwrite=False): for i_source, i_dest in items: i_source = '/mnt/Source{}'.format(i_source) i_dest = '/mnt/UFD{}'.format(i_dest) - recursive_copy(i_source, i_dest, overwrite=overwrite) + try: + recursive_copy(i_source, i_dest, overwrite=overwrite) + except FileNotFoundError: + # Going to assume (hope) that this is fine + pass unmount('/mnt/Source') From 153cda7cf8f6652924bfd588fe6e9bb98b2ad9f4 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 19:27:41 -0700 Subject: [PATCH 63/75] Fixed update_boot_entries() --- .bin/Scripts/functions/ufd.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 1bbe0b53..be341b59 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -361,7 +361,7 @@ def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): # Find config files for c_path, c_ext in boot_files.items(): - c_path = find_path(c_path) + c_path = find_path('/mnt/UFD{}'.format(c_path)) for item in os.scandir(c_path): if item.name.lower().endswith(c_ext.lower()): configs.append(item.path) @@ -377,7 +377,7 @@ def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): run_program(cmd) # Uncomment extra entries if present - for b_path, b_comment in boot_entries: + for b_path, b_comment in boot_entries.items(): try: find_path('/mnt/UFD{}'.format(b_path)) except (FileNotFoundError, NotADirectoryError): From f062f3ce7168e7de14357efc2f5c14a97d8b48c6 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 19:28:15 -0700 Subject: [PATCH 64/75] Fixed source ITEMS --- .bin/Scripts/settings/ufd.py | 48 ++++++++++++++++++------------------ 1 file changed, 24 insertions(+), 24 deletions(-) diff --git a/.bin/Scripts/settings/ufd.py b/.bin/Scripts/settings/ufd.py index db4a2127..94cf333e 100644 --- a/.bin/Scripts/settings/ufd.py +++ b/.bin/Scripts/settings/ufd.py @@ -59,40 +59,40 @@ BOOT_FILES = { ## Sources use rsync's trailing slash syntax ITEMS = { 'Extra Dir': ( - ('/', '/'), + ('/', '/'), ), 'Linux': ( - ('/arch', '/'), - ('/isolinux', '/'), - ('/EFI/boot', '/EFI/'), - ('/EFI/memtest86', '/EFI/'), + ('/arch', '/'), + ('/isolinux', '/'), + ('/EFI/boot', '/EFI/'), + ('/EFI/memtest86', '/EFI/'), ), 'Linux (dGPU)': ( - ('/arch/boot/archiso.img', '/dgpu/'), - ('/arch/boot/vmlinuz', '/dgpu/'), - ('/arch/pkglist.x86_64.txt', '/dgpu/'), - ('/arch/x86_64', '/dgpu/'), + ('/arch/boot/x86_64/archiso.img', '/dgpu/'), + ('/arch/boot/x86_64/vmlinuz', '/dgpu/'), + ('/arch/pkglist.x86_64.txt', '/dgpu/'), + ('/arch/x86_64', '/dgpu/'), ), 'Linux (Minimal)': ( - ('/arch/boot/archiso.img', '/arch_minimal/'), - ('/arch/boot/vmlinuz', '/arch_minimal/'), - ('/arch/pkglist.x86_64.txt', '/arch_minimal/'), - ('/arch/x86_64', '/arch_minimal/'), + ('/arch/boot/x86_64/archiso.img', '/arch_minimal/'), + ('/arch/boot/x86_64/vmlinuz', '/arch_minimal/'), + ('/arch/pkglist.x86_64.txt', '/arch_minimal/'), + ('/arch/x86_64', '/arch_minimal/'), ), 'Main Kit': ( - ('/', '/{}/'.format(KIT_NAME_FULL)), + ('/', '/{}/'.format(KIT_NAME_FULL)), ), 'WinPE': ( - ('/bootmgr', '/'), - ('/bootmgr.efi', '/'), - ('/en_us', '/'), - ('/Boot/', '/boot/'), - ('/EFI/Boot/', '/EFI/Microsoft/'), - ('/EFI/Microsoft/', '/EFI/Microsoft/'), - ('/Boot/BCD', '/sources/'), - ('/Boot/boot.sdi', '/sources/'), - ('/bootmgr', '/sources/'), - ('/sources/boot.wim', '/sources/'), + ('/bootmgr', '/'), + ('/bootmgr.efi', '/'), + ('/en_us', '/'), + ('/Boot/', '/boot/'), + ('/EFI/Boot/', '/EFI/Microsoft/'), + ('/EFI/Microsoft/', '/EFI/Microsoft/'), + ('/Boot/BCD', '/sources/'), + ('/Boot/boot.sdi', '/sources/'), + ('/bootmgr', '/sources/'), + ('/sources/boot.wim', '/sources/'), ), } ITEMS_HIDDEN = ( From 8edf16452225ecc36d5ecac8a4467d20bac2edd5 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 19:29:40 -0700 Subject: [PATCH 65/75] Avoid crash present in archiso v40-1 * Fix is present in upstream archiso-git * iwd would be installed as a dependency for NetworkManager anyway --- .linux_items/packages/live_add | 1 + .linux_items/packages/live_remove | 1 + 2 files changed, 2 insertions(+) diff --git a/.linux_items/packages/live_add b/.linux_items/packages/live_add index 92b92a6c..c01545c5 100644 --- a/.linux_items/packages/live_add +++ b/.linux_items/packages/live_add @@ -16,6 +16,7 @@ e2fsprogs hexedit hfsprogs htop +iwd ldmtool ldns lha diff --git a/.linux_items/packages/live_remove b/.linux_items/packages/live_remove index 9feb3c02..2e1ffbe7 100644 --- a/.linux_items/packages/live_remove +++ b/.linux_items/packages/live_remove @@ -14,6 +14,7 @@ rp-pppoe smartmontools speedtouch testdisk +wpa_actiond vim-minimal vpnc wvdial From b05057d743bb313bc4c3c4ef2841e2d3c7f6a1b1 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 20:00:37 -0700 Subject: [PATCH 66/75] Ignore errors when uncommenting boot entries * Allows using older ISOs which lack newer boot entries * Not a great idea, but it won't crash --- .bin/Scripts/functions/ufd.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index be341b59..c1296d44 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -391,7 +391,7 @@ def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): '"s/#{}#//"'.format(b_comment), *configs, ] - run_program(cmd) + run_program(cmd, check=False) def verify_sources(args, ufd_sources): From 27eb7975ef321bfcc8d5e326c41660dfb4737a53 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 20:51:14 -0700 Subject: [PATCH 67/75] Fixed SYSLINUX installation --- .bin/Scripts/build-ufd | 13 ++++++++++--- .bin/Scripts/functions/ufd.py | 16 ++++++++++++++-- 2 files changed, 24 insertions(+), 5 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 5dd15a7c..4d0072c4 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -92,6 +92,13 @@ if __name__ == '__main__': ufd_label=UFD_LABEL, ) + # Install syslinux (to partition) + try_and_print( + message='Syslinux (partition)...', + function=install_syslinux_to_partition, + partition=find_first_partition(ufd_dev), + ) + # Unmount UFD try_and_print( message='Unmounting UFD...', @@ -99,10 +106,10 @@ if __name__ == '__main__': mount_point='/mnt/UFD', ) - # Install syslinux + # Install syslinux (to device) try_and_print( - message='Installing Syslinux...', - function=install_syslinux, + message='Syslinux (device)...', + function=install_syslinux_to_dev, ufd_dev=ufd_dev, use_mbr=args['--use-mbr'], ) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index c1296d44..897334f6 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -154,8 +154,8 @@ def hide_items(ufd_dev, items): run_program(cmd, check=False, shell=True) -def install_syslinux(ufd_dev, use_mbr): - """Install Syslinux to UFD.""" +def install_syslinux_to_dev(ufd_dev, use_mbr): + """Install Syslinux to UFD (dev).""" cmd = [ 'dd', 'bs=440', @@ -168,6 +168,18 @@ def install_syslinux(ufd_dev, use_mbr): run_program(cmd) +def install_syslinux_to_partition(partition): + """Install Syslinux to UFD (partition).""" + cmd = [ + 'syslinux', + '--install', + '--directory', + '/arch/boot/syslinux/', + partition, + ] + run_program(cmd) + + def is_valid_path(path_obj, path_type): """Verify path_obj is valid by type, returns bool.""" valid_path = False From 72c0e7515655e2c4bca25bb2646528db90e62841 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 20:52:11 -0700 Subject: [PATCH 68/75] Fix mounting UFD --- .bin/Scripts/build-ufd | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 4d0072c4..4ed2212a 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -68,7 +68,7 @@ if __name__ == '__main__': try_and_print( message='Mounting UFD...', function=mount, - mount_source=ufd_dev, + mount_source=find_first_partition(ufd_dev), mount_point='/mnt/UFD', ) From 19799bb1f4594ec554ceb1d85b6a30ba843f4326 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Thu, 18 Apr 2019 20:52:47 -0700 Subject: [PATCH 69/75] Adjusting formatting --- .bin/Scripts/build-ufd | 17 ++++++++++++++++- .bin/Scripts/functions/ufd.py | 6 +++++- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index 4ed2212a..fff63363 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -54,9 +54,11 @@ if __name__ == '__main__': confirm_selections(args) # Prep UFD + print_info('Prep UFD') if args['--update']: # Remove arch folder try_and_print( + indent=2, message='Removing Linux...', function=remove_arch, ) @@ -66,6 +68,7 @@ if __name__ == '__main__': # Mount UFD try_and_print( + indent=2, message='Mounting UFD...', function=mount, mount_source=find_first_partition(ufd_dev), @@ -73,9 +76,12 @@ if __name__ == '__main__': ) # Copy sources + print_standard(' ') + print_info('Copy Sources') for s_label, s_path in sources.items(): try_and_print( - message='Copying {} files...'.format(s_label), + indent=2, + message='Copying {}...'.format(s_label), function=copy_source, source=s_path, items=ITEMS[s_label], @@ -83,7 +89,10 @@ if __name__ == '__main__': ) # Update boot entries + + print_info('Boot Setup') try_and_print( + indent=2, message='Updating boot entries...', function=update_boot_entries, boot_entries=BOOT_ENTRIES, @@ -94,6 +103,7 @@ if __name__ == '__main__': # Install syslinux (to partition) try_and_print( + indent=2, message='Syslinux (partition)...', function=install_syslinux_to_partition, partition=find_first_partition(ufd_dev), @@ -101,6 +111,7 @@ if __name__ == '__main__': # Unmount UFD try_and_print( + indent=2, message='Unmounting UFD...', function=unmount, mount_point='/mnt/UFD', @@ -108,6 +119,7 @@ if __name__ == '__main__': # Install syslinux (to device) try_and_print( + indent=2, message='Syslinux (device)...', function=install_syslinux_to_dev, ufd_dev=ufd_dev, @@ -115,7 +127,10 @@ if __name__ == '__main__': ) # Hide items + print_standard(' ') + print_info('Final Touches') try_and_print( + indent=2, message='Hiding items...', function=hide_items, ufd_dev=ufd_dev, diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 897334f6..c54646b7 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -202,7 +202,7 @@ def mount(mount_source, mount_point): run_program(cmd) -def prep_device(dev_path, label, use_mbr=False): +def prep_device(dev_path, label, use_mbr=False, indent=2): """Format device in preparation for applying the WizardKit components This is done is four steps: @@ -214,6 +214,7 @@ def prep_device(dev_path, label, use_mbr=False): # Zero-out first 64MB cmd = 'dd bs=4M count=16 if=/dev/zero of={}'.format(dev_path).split() try_and_print( + indent=indent, message='Zeroing first 64MB...', function=run_program, cmd=cmd, @@ -226,6 +227,7 @@ def prep_device(dev_path, label, use_mbr=False): '-1s' if use_mbr else '-4MiB', ).split() try_and_print( + indent=indent, message='Creating partition table...', function=run_program, cmd=cmd, @@ -237,6 +239,7 @@ def prep_device(dev_path, label, use_mbr=False): 'boot' if use_mbr else 'legacy_boot', ).split() try_and_print( + indent=indent, message='Setting boot flag...', function=run_program, cmd=cmd, @@ -249,6 +252,7 @@ def prep_device(dev_path, label, use_mbr=False): find_first_partition(dev_path), ] try_and_print( + indent=indent, message='Formatting partition...', function=run_program, cmd=cmd, From 00805395755eaafb79671ab6c7bfe9af1d5a0a5e Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Fri, 19 Apr 2019 14:36:09 -0700 Subject: [PATCH 70/75] Copy the known_networks file to /root/ --- Build Linux | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Build Linux b/Build Linux index 8ed965b5..effd9155 100755 --- a/Build Linux +++ b/Build Linux @@ -281,6 +281,9 @@ function update_live_env() { mkdir -p "$LIVE_DIR/airootfs/usr/share/wallpaper" cp "$ROOT_DIR/Images/Linux.png" "$LIVE_DIR/airootfs/usr/share/wallpaper/burned.in" fi + + # WiFi + cp "$ROOT_DIR/.linux_items/known_networks" "/root/known_networks" } function update_repo() { From e2d788e26563a0e4f1745c06e6e295e3eb310686 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Fri, 19 Apr 2019 15:23:21 -0700 Subject: [PATCH 71/75] Fixed upate_boot_entries() --- .bin/Scripts/functions/ufd.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index c54646b7..96b74b51 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -404,7 +404,7 @@ def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): cmd = [ 'sed', '--in-place', - '"s/#{}#//"'.format(b_comment), + '"s/#UFD-{}#//"'.format(b_comment), *configs, ] run_program(cmd, check=False) From 731a2818053c6224086beec8476940625ea09e2a Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Fri, 19 Apr 2019 16:33:12 -0700 Subject: [PATCH 72/75] More bugfixes --- .bin/Scripts/build-ufd | 2 +- .bin/Scripts/functions/ufd.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.bin/Scripts/build-ufd b/.bin/Scripts/build-ufd index fff63363..bb0813a8 100755 --- a/.bin/Scripts/build-ufd +++ b/.bin/Scripts/build-ufd @@ -89,7 +89,7 @@ if __name__ == '__main__': ) # Update boot entries - + print_standard(' ') print_info('Boot Setup') try_and_print( indent=2, diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 96b74b51..95a55b64 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -404,7 +404,7 @@ def update_boot_entries(boot_entries, boot_files, iso_label, ufd_label): cmd = [ 'sed', '--in-place', - '"s/#UFD-{}#//"'.format(b_comment), + 's/#{}#//'.format(b_comment), *configs, ] run_program(cmd, check=False) From a83dcdd06a7ab293120b4d5e9ae1ea587a7d3dc0 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Fri, 19 Apr 2019 18:14:10 -0700 Subject: [PATCH 73/75] Handle non-ISO source items --- .bin/Scripts/functions/ufd.py | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/.bin/Scripts/functions/ufd.py b/.bin/Scripts/functions/ufd.py index 95a55b64..598985d3 100644 --- a/.bin/Scripts/functions/ufd.py +++ b/.bin/Scripts/functions/ufd.py @@ -59,17 +59,29 @@ def confirm_selections(args): def copy_source(source, items, overwrite=False): - """Mount source and copy items to /mnt/UFD.""" - mount(source, '/mnt/Source') + """Copy source items to /mnt/UFD.""" + is_iso = source.name.lower().endswith('.iso') + + # Mount source if necessary + if is_iso: + mount(source, '/mnt/Source') + + # Copy items for i_source, i_dest in items: - i_source = '/mnt/Source{}'.format(i_source) + i_source = '{}{}'.format( + '/mnt/Source' if is_iso else source, + i_source, + ) i_dest = '/mnt/UFD{}'.format(i_dest) try: recursive_copy(i_source, i_dest, overwrite=overwrite) except FileNotFoundError: # Going to assume (hope) that this is fine pass - unmount('/mnt/Source') + + # Unmount source if necessary + if is_iso: + unmount('/mnt/Source') def find_first_partition(dev_path): From 9502ea0bbcedbe6aeaeb59b7513ec26117ecb5a8 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Fri, 19 Apr 2019 19:02:38 -0700 Subject: [PATCH 74/75] Deleted old build-ufd (BASH) --- .bin/Scripts/build-ufd.bash | 671 ------------------------------------ 1 file changed, 671 deletions(-) delete mode 100755 .bin/Scripts/build-ufd.bash diff --git a/.bin/Scripts/build-ufd.bash b/.bin/Scripts/build-ufd.bash deleted file mode 100755 index 5f272d7d..00000000 --- a/.bin/Scripts/build-ufd.bash +++ /dev/null @@ -1,671 +0,0 @@ -#!/usr/bin/env bash -# -## Wizard Kit: UFD Build Tool -# -# Based on a template by BASH3 Boilerplate v2.3.0 -# http://bash3boilerplate.sh/#authors -# -# The MIT License (MIT) -# Copyright (c) 2013 Kevin van Zonneveld and contributors -# You are not obligated to bundle the LICENSE file with your b3bp projects as long -# as you leave these references intact in the header comments of your source files. - -# Exit on error. Append "|| true" if you expect an error. -set -o errexit -# Exit on error inside any functions or subshells. -set -o errtrace -# Do not allow use of undefined vars. Use ${VAR:-} to use an undefined VAR -set -o nounset -# Catch the error in case mysqldump fails (but gzip succeeds) in `mysqldump |gzip` -set -o pipefail -# Turn on traces, useful while debugging but commented out by default -# set -o xtrace - -if [[ "${BASH_SOURCE[0]}" != "${0}" ]]; then - __i_am_main_script="0" # false - - if [[ "${__usage+x}" ]]; then - if [[ "${BASH_SOURCE[1]}" = "${0}" ]]; then - __i_am_main_script="1" # true - fi - - __b3bp_external_usage="true" - __b3bp_tmp_source_idx=1 - fi -else - __i_am_main_script="1" # true - [[ "${__usage+x}" ]] && unset -v __usage - [[ "${__helptext+x}" ]] && unset -v __helptext -fi - -# Set magic variables for current file, directory, os, etc. -__dir="$(cd "$(dirname "${BASH_SOURCE[${__b3bp_tmp_source_idx:-0}]}")" && pwd)" -__file="${__dir}/$(basename "${BASH_SOURCE[${__b3bp_tmp_source_idx:-0}]}")" -__base="$(basename "${__file}" .sh)" -__wd="$(pwd)" -__usage_example="Usage: sudo $(basename "${0}") --ufd-device [device] --linux-iso [path] --main-kit [path] --winpe-iso [path]" -__all_args="" -for a in "${@}"; do - if [[ "${a:0:1}" == "-" ]]; then - __all_args="${__all_args} ${a}" - else - __all_args="${__all_args} \"${a}\"" - fi -done - - -# Define the environment variables (and their defaults) that this script depends on -LOG_LEVEL="${LOG_LEVEL:-6}" # 7 = debug -> 0 = emergency -NO_COLOR="${NO_COLOR:-}" # true = disable color. otherwise autodetected - - -### Functions -############################################################################## - -function __b3bp_log () { - local log_level="${1}" - shift - - # shellcheck disable=SC2034 - local color_debug="\x1b[35m" - # shellcheck disable=SC2034 - local color_info="\x1b[32m" - # shellcheck disable=SC2034 - local color_notice="\x1b[34m" - # shellcheck disable=SC2034 - local color_warning="\x1b[33m" - # shellcheck disable=SC2034 - local color_error="\x1b[31m" - # shellcheck disable=SC2034 - local color_critical="\x1b[1;31m" - # shellcheck disable=SC2034 - local color_alert="\x1b[1;33;41m" - # shellcheck disable=SC2034 - local color_emergency="\x1b[1;4;5;33;41m" - - local colorvar="color_${log_level}" - - local color="${!colorvar:-${color_error}}" - local color_reset="\x1b[0m" - - if [[ "${NO_COLOR:-}" = "true" ]] || ( [[ "${TERM:-}" != *"256color"* ]] && [[ "${TERM:-}" != "xterm"* ]] && [[ "${TERM:-}" != "screen"* ]] ) || [[ ! -t 2 ]]; then - if [[ "${NO_COLOR:-}" != "false" ]]; then - # Don't use colors on pipes or non-recognized terminals - color=""; color_reset="" - fi - fi - - # all remaining arguments are to be printed - local log_line="" - - while IFS=$'\n' read -r log_line; do - echo -e "$(date -u +"%Y-%m-%d %H:%M:%S UTC") ${color}$(printf "[%9s]" "${log_level}")${color_reset} ${log_line}" 1>&2 - done <<< "${@:-}" -} - -function emergency () { __b3bp_log emergency "${@}"; exit 1; } -function alert () { [[ "${LOG_LEVEL:-0}" -ge 1 ]] && __b3bp_log alert "${@}"; true; } -function critical () { [[ "${LOG_LEVEL:-0}" -ge 2 ]] && __b3bp_log critical "${@}"; true; } -function error () { [[ "${LOG_LEVEL:-0}" -ge 3 ]] && __b3bp_log error "${@}"; true; } -function warning () { [[ "${LOG_LEVEL:-0}" -ge 4 ]] && __b3bp_log warning "${@}"; true; } -function notice () { [[ "${LOG_LEVEL:-0}" -ge 5 ]] && __b3bp_log notice "${@}"; true; } -function info () { [[ "${LOG_LEVEL:-0}" -ge 6 ]] && __b3bp_log info "${@}"; true; } -function debug () { [[ "${LOG_LEVEL:-0}" -ge 7 ]] && __b3bp_log debug "${@}"; true; } - -function help () { - echo "" 1>&2 - echo " ${*}" 1>&2 - echo "" 1>&2 - echo " ${__usage:-No usage available}" 1>&2 - echo "" 1>&2 - - if [[ "${__helptext:-}" ]]; then - echo " ${__helptext}" 1>&2 - echo "" 1>&2 - fi - - exit 1 -} - - -### Parse commandline options -############################################################################## - -# Commandline options. This defines the usage page, and is used to parse cli -# opts & defaults from. The parsing is unforgiving so be precise in your syntax -# - A short option must be preset for every long option; but every short option -# need not have a long option -# - `--` is respected as the separator between options and arguments -# - We do not bash-expand defaults, so setting '~/app' as a default will not resolve to ${HOME}. -# you can use bash variables to work around this (so use ${HOME} instead) - -# shellcheck disable=SC2015 -[[ "${__usage+x}" ]] || read -r -d '' __usage <<-'EOF' || true # exits non-zero when EOF encountered - OPTIONS: - -u --ufd-device [arg] Device to which the kit will be applied - -l --linux-iso [arg] Path to the Linux ISO - - -e --extra-dir [arg] Path to the Extra folder (optional) - -m --main-kit [arg] Path to the Main Kit (optional) - -w --winpe-iso [arg] Path to the WinPE ISO (optional) - -h --help This page - - ADVANCED: - -d --debug Enable debug mode - -v --verbose Enable verbose mode - -M --use-mbr Use real MBR instead of GPT w/ Protective MBR - -F --force Bypass all confirmation messages. USE WITH EXTREME CAUTION! -EOF - -# shellcheck disable=SC2015 -[[ "${__helptext+x}" ]] || read -r -d '' __helptext <<-'EOF' || true # exits non-zero when EOF encountered - Paths can be relative to the current working directory or absolute -EOF - -# Translate usage string -> getopts arguments, and set $arg_ defaults -while read -r __b3bp_tmp_line; do - if [[ "${__b3bp_tmp_line}" =~ ^- ]]; then - # fetch single character version of option string - __b3bp_tmp_opt="${__b3bp_tmp_line%% *}" - __b3bp_tmp_opt="${__b3bp_tmp_opt:1}" - - # fetch long version if present - __b3bp_tmp_long_opt="" - - if [[ "${__b3bp_tmp_line}" = *"--"* ]]; then - __b3bp_tmp_long_opt="${__b3bp_tmp_line#*--}" - __b3bp_tmp_long_opt="${__b3bp_tmp_long_opt%% *}" - fi - - # map opt long name to+from opt short name - printf -v "__b3bp_tmp_opt_long2short_${__b3bp_tmp_long_opt//-/_}" '%s' "${__b3bp_tmp_opt}" - printf -v "__b3bp_tmp_opt_short2long_${__b3bp_tmp_opt}" '%s' "${__b3bp_tmp_long_opt//-/_}" - - # check if option takes an argument - if [[ "${__b3bp_tmp_line}" =~ \[.*\] ]]; then - __b3bp_tmp_opt="${__b3bp_tmp_opt}:" # add : if opt has arg - __b3bp_tmp_init="" # it has an arg. init with "" - printf -v "__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" '%s' "1" - elif [[ "${__b3bp_tmp_line}" =~ \{.*\} ]]; then - __b3bp_tmp_opt="${__b3bp_tmp_opt}:" # add : if opt has arg - __b3bp_tmp_init="" # it has an arg. init with "" - # remember that this option requires an argument - printf -v "__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" '%s' "2" - else - __b3bp_tmp_init="0" # it's a flag. init with 0 - printf -v "__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" '%s' "0" - fi - __b3bp_tmp_opts="${__b3bp_tmp_opts:-}${__b3bp_tmp_opt}" - fi - - [[ "${__b3bp_tmp_opt:-}" ]] || continue - - if [[ "${__b3bp_tmp_line}" =~ (^|\.\ *)Default= ]]; then - # ignore default value if option does not have an argument - __b3bp_tmp_varname="__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" - - if [[ "${!__b3bp_tmp_varname}" != "0" ]]; then - __b3bp_tmp_init="${__b3bp_tmp_line##*Default=}" - __b3bp_tmp_re='^"(.*)"$' - if [[ "${__b3bp_tmp_init}" =~ ${__b3bp_tmp_re} ]]; then - __b3bp_tmp_init="${BASH_REMATCH[1]}" - else - __b3bp_tmp_re="^'(.*)'$" - if [[ "${__b3bp_tmp_init}" =~ ${__b3bp_tmp_re} ]]; then - __b3bp_tmp_init="${BASH_REMATCH[1]}" - fi - fi - fi - fi - - if [[ "${__b3bp_tmp_line}" =~ (^|\.\ *)Required\. ]]; then - # remember that this option requires an argument - printf -v "__b3bp_tmp_has_arg_${__b3bp_tmp_opt:0:1}" '%s' "2" - fi - - printf -v "arg_${__b3bp_tmp_opt:0:1}" '%s' "${__b3bp_tmp_init}" -done <<< "${__usage:-}" - -# run getopts only if options were specified in __usage -if [[ "${__b3bp_tmp_opts:-}" ]]; then - # Allow long options like --this - __b3bp_tmp_opts="${__b3bp_tmp_opts}-:" - - # Reset in case getopts has been used previously in the shell. - OPTIND=1 - - # start parsing command line - set +o nounset # unexpected arguments will cause unbound variables - # to be dereferenced - # Overwrite $arg_ defaults with the actual CLI options - while getopts "${__b3bp_tmp_opts}" __b3bp_tmp_opt; do - [[ "${__b3bp_tmp_opt}" = "?" ]] && help "Invalid use of script: ${*} " - - if [[ "${__b3bp_tmp_opt}" = "-" ]]; then - # OPTARG is long-option-name or long-option=value - if [[ "${OPTARG}" =~ .*=.* ]]; then - # --key=value format - __b3bp_tmp_long_opt=${OPTARG/=*/} - # Set opt to the short option corresponding to the long option - __b3bp_tmp_varname="__b3bp_tmp_opt_long2short_${__b3bp_tmp_long_opt//-/_}" - printf -v "__b3bp_tmp_opt" '%s' "${!__b3bp_tmp_varname}" - OPTARG=${OPTARG#*=} - else - # --key value format - # Map long name to short version of option - __b3bp_tmp_varname="__b3bp_tmp_opt_long2short_${OPTARG//-/_}" - printf -v "__b3bp_tmp_opt" '%s' "${!__b3bp_tmp_varname}" - # Only assign OPTARG if option takes an argument - __b3bp_tmp_varname="__b3bp_tmp_has_arg_${__b3bp_tmp_opt}" - printf -v "OPTARG" '%s' "${@:OPTIND:${!__b3bp_tmp_varname}}" - # shift over the argument if argument is expected - ((OPTIND+=__b3bp_tmp_has_arg_${__b3bp_tmp_opt})) - fi - # we have set opt/OPTARG to the short value and the argument as OPTARG if it exists - fi - __b3bp_tmp_varname="arg_${__b3bp_tmp_opt:0:1}" - __b3bp_tmp_default="${!__b3bp_tmp_varname}" - - __b3bp_tmp_value="${OPTARG}" - if [[ -z "${OPTARG}" ]] && [[ "${__b3bp_tmp_default}" = "0" ]]; then - __b3bp_tmp_value="1" - fi - - printf -v "${__b3bp_tmp_varname}" '%s' "${__b3bp_tmp_value}" - debug "cli arg ${__b3bp_tmp_varname} = (${__b3bp_tmp_default}) -> ${!__b3bp_tmp_varname}" - done - set -o nounset # no more unbound variable references expected - - shift $((OPTIND-1)) - - if [[ "${1:-}" = "--" ]] ; then - shift - fi -fi - - -### Automatic validation of required option arguments -############################################################################## - -for __b3bp_tmp_varname in ${!__b3bp_tmp_has_arg_*}; do - # validate only options which required an argument - [[ "${!__b3bp_tmp_varname}" = "2" ]] || continue - - __b3bp_tmp_opt_short="${__b3bp_tmp_varname##*_}" - __b3bp_tmp_varname="arg_${__b3bp_tmp_opt_short}" - [[ "${!__b3bp_tmp_varname}" ]] && continue - - __b3bp_tmp_varname="__b3bp_tmp_opt_short2long_${__b3bp_tmp_opt_short}" - printf -v "__b3bp_tmp_opt_long" '%s' "${!__b3bp_tmp_varname}" - [[ "${__b3bp_tmp_opt_long:-}" ]] && __b3bp_tmp_opt_long=" (--${__b3bp_tmp_opt_long//_/-})" - - help "Option -${__b3bp_tmp_opt_short}${__b3bp_tmp_opt_long:-} requires an argument" -done - - -### Cleanup Environment variables -############################################################################## - -for __tmp_varname in ${!__b3bp_tmp_*}; do - unset -v "${__tmp_varname}" -done - -unset -v __tmp_varname - - -### Externally supplied __usage. Nothing else to do here -############################################################################## - -if [[ "${__b3bp_external_usage:-}" = "true" ]]; then - unset -v __b3bp_external_usage - return -fi - - -### Signal trapping and backtracing -############################################################################## - -function __b3bp_cleanup_before_exit () { - if [[ "$EUID" -eq 0 ]]; then - for d in Dest Linux WinPE; do - if [[ -d "/mnt/${d}" ]]; then - umount "/mnt/${d}" || true - rmdir "/mnt/${d}" || true - fi - done - fi - if [[ "${?}" != "0" ]]; then - info "Sources unmounted" - fi - if [[ ${arg_F:-} == 0 && "${SILENT:-False}" == "False" ]]; then - read -r -p "Press Enter to exit... " ignored_var 2>&1 - fi -} -trap __b3bp_cleanup_before_exit EXIT - -# requires `set -o errtrace` -__b3bp_err_report() { - local error_code - error_code=${?} - error "Error in ${__file} in function ${1} on line ${2}" - exit ${error_code} -} -# Uncomment the following line for always providing an error backtrace -trap '__b3bp_err_report "${FUNCNAME:-.}" ${LINENO}' ERR - - -### Command-line argument switches (like -d for debugmode, -h for showing helppage) -############################################################################## - -# debug mode -if [[ "${arg_d:?}" = "1" ]]; then - set -o xtrace - LOG_LEVEL="7" - # Enable error backtracing - trap '__b3bp_err_report "${FUNCNAME:-.}" ${LINENO}' ERR -fi - -# verbose mode -if [[ "${arg_v:?}" = "1" ]]; then - set -o verbose -fi - - -### Validation. Error out if the things required for your script are not present -############################################################################## - -if [[ "${arg_F:?}" == 1 ]]; then - SILENT="True" -else - SILENT="False" -fi -if [[ "${arg_M:?}" == 1 ]]; then - USE_MBR="True" -else - USE_MBR="False" -fi - -if [[ "${arg_h:?}" == 1 ]]; then - help "${__usage_example}" -else - # Print warning line - [[ "${arg_u:-}" ]] || echo " -u or --ufd-device is required" - [[ "${arg_l:-}" ]] || echo " -l or --linux-iso is required" - - # Bail if necessary - [[ "${arg_u:-}" ]] || help "${__usage_example}" - [[ "${arg_l:-}" ]] || help "${__usage_example}" -fi -[[ "${LOG_LEVEL:-}" ]] || emergency "Cannot continue without LOG_LEVEL. " - - -### More functions -############################################################################## - -function abort () { - local abort_message="Aborted" - [[ "${1:-}" ]] && abort_message="${1}" || true - error "${abort_message}" - #echo -e "${YELLOW}${abort_message}${CLEAR}" - exit 1 -} - -function ask() { - if [[ "${SILENT}" == "True" ]]; then - echo -e "${1:-} Yes ${BLUE}(Silent)${CLEAR}" - return 0 - fi - while :; do - read -p "${1:-} [Y/N] " -r answer - if echo "$answer" | egrep -iq '^(y|yes|sure)$'; then - return 0 - elif echo "$answer" | egrep -iq '^(n|no|nope)$'; then - return 1 - fi - done -} - - -### Runtime -############################################################################## - -# VARIABLES -DEST_DEV="${arg_u}" -DEST_PAR="${DEST_DEV}1" -LOG_FILE="$(getent passwd "$SUDO_USER" | cut -d: -f6)/Logs/build-ufd_${DEST_DEV##*/}_$(date +%Y-%m-%d_%H%M_%z).log" -MAIN_PY="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/settings/main.py" -RSYNC_ARGS="-hrtuvS --modify-window=1 --progress" -MAIN_KIT="$(realpath "${arg_m:-}" 2>/dev/null || true)" -LINUX_ISO="$(realpath "${arg_l:-}" 2>/dev/null || true)" -WINPE_ISO="$(realpath "${arg_w:-}" 2>/dev/null || true)" -EXTRA_DIR="$(realpath "${arg_e:-}" 2>/dev/null || true)" -mkdir -p "$(dirname "$LOG_FILE")" -chown "$SUDO_USER:$SUDO_USER" -R "$(dirname "$LOG_FILE")" - -# COLORS -CLEAR="\e[0m" -RED="\e[31m" -GREEN="\e[32m" -YELLOW="\e[33m" -BLUE="\e[34m" - -# Load main.py settings -if [ ! -f "${MAIN_PY}" ]; then - echo -e "${RED}ERROR${CLEAR}: ${MAIN_PY} not found." - abort -fi -while read line; do - if echo "${line}" | egrep -q "^\w+='"; then - line="$(echo "${line}" | sed -r 's/[\r\n]+//')" - eval "${line}" - fi -done < "${MAIN_PY}" -if [ -z ${KIT_NAME_FULL+x} ]; then - # KIT_NAME_FULL is not set, assume main.py missing or malformatted - echo -e "${RED}ERROR${CLEAR}: failed to load settings from ${MAIN_PY}" - abort -fi -ISO_LABEL="${KIT_NAME_SHORT}_LINUX" -UFD_LABEL="${KIT_NAME_SHORT}_UFD" - -# Check if root -if [[ "$EUID" -ne 0 ]]; then - echo -e "${RED}ERROR${CLEAR}: This script must be run as root." - abort -fi - -# Check if in tmux -if ! tmux list-session 2>/dev/null | grep -q "build-ufd"; then - # Reload in tmux - eval tmux new-session -s "build-ufd" "${0:-}" ${__all_args} - SILENT="True" # avoid two "Press Enter to exit..." prompts - exit 0 -fi - -# Header -echo -e "${GREEN}${KIT_NAME_FULL}${CLEAR}: UFD Build Tool" -echo "" - -# Verify sources -[[ -b "${DEST_DEV}" ]] || abort "${DEST_DEV} is not a valid device." -[[ -e "${LINUX_ISO}" ]] || abort "Linux ISO not found." -if [[ ! -z "${arg_m:-}" ]]; then - [[ -d "${MAIN_KIT}/.bin" ]] || abort "Invalid Main Kit, ${MAIN_KIT}/.bin not found." -fi -if [[ ! -z "${arg_w:-}" ]]; then - [[ -e "${WINPE_ISO}" ]] || abort "WinPE ISO not found." -fi -if [[ ! -z "${arg_e:-}" ]]; then - [[ -d "${EXTRA_DIR}" ]] || abort "Extra Dir not found." -fi - -# Print Info -echo -e "${BLUE}Sources${CLEAR}" | tee -a "${LOG_FILE}" -echo "Main Kit: ${MAIN_KIT}" | tee -a "${LOG_FILE}" -echo "Linux ISO: ${LINUX_ISO}" | tee -a "${LOG_FILE}" -echo "WinPE ISO: ${WINPE_ISO}" | tee -a "${LOG_FILE}" -echo "Extra Dir: ${EXTRA_DIR:-(Not Specified)}" | tee -a "${LOG_FILE}" -echo "" | tee -a "${LOG_FILE}" -echo -e "${BLUE}Destination${CLEAR}" | tee -a "${LOG_FILE}" -lsblk -n -o NAME,LABEL,SIZE,MODEL,SERIAL "${DEST_DEV}" | tee -a "${LOG_FILE}" -if [[ "${USE_MBR}" == "True" ]]; then - echo -e "${YELLOW}Formatting using legacy MBR${CLEAR}" | tee -a "${LOG_FILE}" -fi -echo "" | tee -a "${LOG_FILE}" - -# Ask before starting job -echo "" -if ask "Is the above information correct?"; then - echo "" - echo -e "${YELLOW}SAFETY CHECK${CLEAR}" - echo "All data will be DELETED from the disk and partition(s) listed above." - echo -e "This is irreversible and will lead to ${RED}DATA LOSS.${CLEAR}" - if ! ask "Asking again to confirm, is this correct?"; then - abort - fi -else - abort -fi - -# Start Build -echo "" | tee -a "${LOG_FILE}" -echo -e "${GREEN}Building Kit${CLEAR}" | tee -a "${LOG_FILE}" -touch "${LOG_FILE}" -tmux split-window -dl 10 tail -f "${LOG_FILE}" - -# Zero beginning of device -dd bs=4M count=16 if=/dev/zero of="${DEST_DEV}" >> "${LOG_FILE}" 2>&1 - -# Format -echo "Formatting drive..." | tee -a "${LOG_FILE}" -if [[ "${USE_MBR}" == "True" ]]; then - parted "${DEST_DEV}" --script -- mklabel msdos mkpart primary fat32 4MiB -1s >> "${LOG_FILE}" 2>&1 - parted "${DEST_DEV}" set 1 boot on >> "${LOG_FILE}" 2>&1 -else - parted "${DEST_DEV}" --script -- mklabel gpt mkpart primary fat32 4MiB -4MiB >> "${LOG_FILE}" 2>&1 - parted "${DEST_DEV}" set 1 legacy_boot on >> "${LOG_FILE}" 2>&1 - #parted "${DEST_DEV}" disk_set pmbr_boot on >> "${LOG_FILE}" 2>&1 - # pmbr_boot breaks detection on some UEFI MOBOs -fi -mkfs.vfat -F 32 -n "${UFD_LABEL}" "${DEST_PAR}" >> "${LOG_FILE}" 2>&1 - -# Mount sources and dest -echo "Mounting sources and destination..." | tee -a "${LOG_FILE}" -mkdir /mnt/{Dest,Linux,WinPE} -p >> "${LOG_FILE}" 2>&1 -mount ${DEST_PAR} /mnt/Dest >> "${LOG_FILE}" 2>&1 -mount "${LINUX_ISO}" /mnt/Linux -r >> "${LOG_FILE}" 2>&1 -if [[ ! -z "${arg_w:-}" ]]; then - mount "${WINPE_ISO}" /mnt/WinPE -r >> "${LOG_FILE}" 2>&1 -fi - -# Find WinPE source -w_boot="$(find /mnt/WinPE -iwholename "/mnt/WinPE/Boot")" -w_boot_bcd="$(find /mnt/WinPE -iwholename "/mnt/WinPE/Boot/BCD")" -w_boot_sdi="$(find /mnt/WinPE -iwholename "/mnt/WinPE/Boot/boot.sdi")" -w_bootmgr="$(find /mnt/WinPE -iwholename "/mnt/WinPE/bootmgr")" -w_bootmgr_efi="$(find /mnt/WinPE -iwholename "/mnt/WinPE/bootmgr.efi")" -w_efi_boot="$(find /mnt/WinPE -iwholename "/mnt/WinPE/EFI/Boot")" -w_efi_microsoft="$(find /mnt/WinPE -iwholename "/mnt/WinPE/EFI/Microsoft")" -w_en_us="$(find /mnt/WinPE -iwholename "/mnt/WinPE/en-us")" -w_sources="$(find /mnt/WinPE -iwholename "/mnt/WinPE/sources")" - -# Copy files -echo "Copying Linux files..." | tee -a "${LOG_FILE}" -rsync ${RSYNC_ARGS} /mnt/Linux/* /mnt/Dest/ >> "${LOG_FILE}" 2>&1 -sed -i "s/${ISO_LABEL}/${UFD_LABEL}/" /mnt/Dest/EFI/boot/refind.conf -sed -i "s/${ISO_LABEL}/${UFD_LABEL}/" /mnt/Dest/arch/boot/syslinux/*cfg - -echo "Copying WinPE files..." | tee -a "${LOG_FILE}" -if [[ ! -z "${arg_w:-}" ]]; then - if [[ ! -z "${w_bootmgr:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_bootmgr}" /mnt/Dest/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_bootmgr_efi:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_bootmgr_efi}" /mnt/Dest/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_en_us:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_en_us}" /mnt/Dest/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_boot:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_boot}"/* /mnt/Dest/Boot/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_efi_boot:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_efi_boot}"/* /mnt/Dest/EFI/Microsoft/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_efi_microsoft:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_efi_microsoft}"/* /mnt/Dest/EFI/Microsoft/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_boot_bcd:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_boot_bcd}" /mnt/Dest/sources/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_boot_sdi:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_boot_sdi}" /mnt/Dest/sources/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_bootmgr:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_bootmgr}" /mnt/Dest/sources/ >> "${LOG_FILE}" 2>&1 - fi - if [[ ! -z "${w_sources:-}" ]]; then - rsync ${RSYNC_ARGS} "${w_sources}"/* /mnt/Dest/sources/ >> "${LOG_FILE}" 2>&1 - fi - - # Uncomment boot entries - sed -i "s/#UFD-WINPE#//" /mnt/Dest/EFI/boot/refind.conf - sed -i "s/#UFD-WINPE#//" /mnt/Dest/arch/boot/syslinux/*cfg -fi - -echo "Copying Main Kit..." | tee -a "${LOG_FILE}" -if [[ ! -z "${arg_m:-}" ]]; then - rsync ${RSYNC_ARGS} \ - "${MAIN_KIT}/" \ - "/mnt/Dest/${KIT_NAME_FULL}/" >> "${LOG_FILE}" 2>&1 -fi - -if [[ ! -z "${EXTRA_DIR:-}" ]]; then - echo "Copying Extra files..." | tee -a "${LOG_FILE}" - rsync ${RSYNC_ARGS} \ - "${EXTRA_DIR}"/ \ - /mnt/Dest/ >> "${LOG_FILE}" 2>&1 -fi - -# Install syslinux -echo "Copying Syslinux files..." | tee -a "${LOG_FILE}" -rsync ${RSYNC_ARGS} /usr/lib/syslinux/bios/*.c32 /mnt/Dest/arch/boot/syslinux/ >> "${LOG_FILE}" 2>&1 -syslinux --install -d /arch/boot/syslinux/ ${DEST_PAR} >> "${LOG_FILE}" 2>&1 - -echo "Unmounting destination..." | tee -a "${LOG_FILE}" -umount /mnt/Dest >> "${LOG_FILE}" 2>&1 -rmdir /mnt/Dest >> "${LOG_FILE}" 2>&1 -sync - -echo "Installing Syslinux MBR..." | tee -a "${LOG_FILE}" -if [[ "${USE_MBR}" == "True" ]]; then - dd bs=440 count=1 if=/usr/lib/syslinux/bios/mbr.bin of=${DEST_DEV} >> "${LOG_FILE}" 2>&1 -else - dd bs=440 count=1 if=/usr/lib/syslinux/bios/gptmbr.bin of=${DEST_DEV} >> "${LOG_FILE}" 2>&1 -fi -sync - -# Cleanup -echo "Hiding boot files..." | tee -a "${LOG_FILE}" -echo "drive s: file=\"${DEST_PAR}\"" > /root/.mtoolsrc -echo 'mtools_skip_check=1' >> /root/.mtoolsrc -for item in arch Boot bootmgr{,.efi} EFI en-us images isolinux sources "${KIT_NAME_FULL}"/{.bin,.cbin}; do - yes | mattrib +h "S:/${item}" >> "${LOG_FILE}" 2>&1 || true -done -sync - -# Unmount Sources -echo "Unmounting sources..." | tee -a "${LOG_FILE}" -for d in Linux WinPE; do - umount "/mnt/${d}" >> "${LOG_FILE}" 2>&1 || true - rmdir "/mnt/${d}" >> "${LOG_FILE}" 2>&1 || true -done - -# Close progress pane -pkill -f "tail.*${LOG_FILE}" - -# Done -echo "" | tee -a "${LOG_FILE}" -echo "Done." | tee -a "${LOG_FILE}" -echo "" -exit 0 From 5756d14292221fd0460e53a911cc5ae0e60b61e9 Mon Sep 17 00:00:00 2001 From: 2Shirt <2xShirt@gmail.com> Date: Fri, 19 Apr 2019 19:16:25 -0700 Subject: [PATCH 75/75] Fix issue #102 --- .bin/Scripts/activate.py | 4 ++-- .bin/Scripts/cbs_fix.py | 4 ++-- .bin/Scripts/check_disk.py | 4 ++-- .bin/Scripts/ddrescue-tui-menu | 4 ++-- .bin/Scripts/dism.py | 4 ++-- .bin/Scripts/hw-diags-audio | 4 ++-- .bin/Scripts/hw-diags-menu | 5 ++--- .bin/Scripts/hw-diags-network | 4 ++-- .bin/Scripts/hw-sensors-monitor | 4 ++-- .bin/Scripts/install_sw_bundle.py | 4 ++-- .bin/Scripts/install_vcredists.py | 4 ++-- .bin/Scripts/mount-all-volumes | 4 ++-- .bin/Scripts/mount-backup-shares | 4 ++-- .bin/Scripts/msword-search | 4 ++-- .bin/Scripts/new_system_setup.py | 4 ++-- .bin/Scripts/safemode_enter.py | 4 ++-- .bin/Scripts/safemode_exit.py | 4 ++-- .bin/Scripts/sfc_scan.py | 4 ++-- .bin/Scripts/system_checklist.py | 4 ++-- .bin/Scripts/system_diagnostics.py | 4 ++-- .bin/Scripts/transferred_keys.py | 4 ++-- .bin/Scripts/update_kit.py | 4 ++-- .bin/Scripts/user_checklist.py | 4 ++-- .bin/Scripts/user_data_transfer.py | 4 ++-- .bin/Scripts/winpe_root_menu.py | 4 ++-- 25 files changed, 50 insertions(+), 51 deletions(-) diff --git a/.bin/Scripts/activate.py b/.bin/Scripts/activate.py index f9a9c69d..fa54fa5d 100644 --- a/.bin/Scripts/activate.py +++ b/.bin/Scripts/activate.py @@ -55,8 +55,8 @@ if __name__ == '__main__': print_success('\nDone.') pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/cbs_fix.py b/.bin/Scripts/cbs_fix.py index 36a7906f..167f95aa 100644 --- a/.bin/Scripts/cbs_fix.py +++ b/.bin/Scripts/cbs_fix.py @@ -35,8 +35,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/check_disk.py b/.bin/Scripts/check_disk.py index 5b0f3c14..8919063e 100644 --- a/.bin/Scripts/check_disk.py +++ b/.bin/Scripts/check_disk.py @@ -49,8 +49,8 @@ if __name__ == '__main__': print_success('Done.') pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/ddrescue-tui-menu b/.bin/Scripts/ddrescue-tui-menu index a6014d76..f65e24e1 100755 --- a/.bin/Scripts/ddrescue-tui-menu +++ b/.bin/Scripts/ddrescue-tui-menu @@ -54,8 +54,8 @@ if __name__ == '__main__': msg = str(ge) print_error(msg) abort() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/dism.py b/.bin/Scripts/dism.py index 2ef3ff25..4de5b788 100644 --- a/.bin/Scripts/dism.py +++ b/.bin/Scripts/dism.py @@ -50,8 +50,8 @@ if __name__ == '__main__': print_success('Done.') pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/hw-diags-audio b/.bin/Scripts/hw-diags-audio index 3d3a5991..e581330f 100755 --- a/.bin/Scripts/hw-diags-audio +++ b/.bin/Scripts/hw-diags-audio @@ -34,8 +34,8 @@ if __name__ == '__main__': #print_standard('\nDone.') #pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/hw-diags-menu b/.bin/Scripts/hw-diags-menu index fa7f0cd8..1c241bf9 100755 --- a/.bin/Scripts/hw-diags-menu +++ b/.bin/Scripts/hw-diags-menu @@ -22,9 +22,8 @@ if __name__ == '__main__': print_standard(' ') sleep(1) pause('Press Enter to exit...') - except SystemExit: - # Normal exit - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: # Cleanup tmux_kill_all_panes() diff --git a/.bin/Scripts/hw-diags-network b/.bin/Scripts/hw-diags-network index 3047e131..138ea67e 100755 --- a/.bin/Scripts/hw-diags-network +++ b/.bin/Scripts/hw-diags-network @@ -40,8 +40,8 @@ if __name__ == '__main__': print_standard('\nDone.') #pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/hw-sensors-monitor b/.bin/Scripts/hw-sensors-monitor index c27d786a..ffdbbad3 100755 --- a/.bin/Scripts/hw-sensors-monitor +++ b/.bin/Scripts/hw-sensors-monitor @@ -28,8 +28,8 @@ if __name__ == '__main__': run_program(cmd, check=False) monitor_sensors(monitor_pane, monitor_file) exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/install_sw_bundle.py b/.bin/Scripts/install_sw_bundle.py index 0faec26e..b536fd64 100644 --- a/.bin/Scripts/install_sw_bundle.py +++ b/.bin/Scripts/install_sw_bundle.py @@ -59,8 +59,8 @@ if __name__ == '__main__': other_results=other_results) print_standard('\nDone.') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/install_vcredists.py b/.bin/Scripts/install_vcredists.py index a22cc729..1cd31d95 100644 --- a/.bin/Scripts/install_vcredists.py +++ b/.bin/Scripts/install_vcredists.py @@ -27,8 +27,8 @@ if __name__ == '__main__': print_standard('\nDone.') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/mount-all-volumes b/.bin/Scripts/mount-all-volumes index f49439f2..5b34c579 100755 --- a/.bin/Scripts/mount-all-volumes +++ b/.bin/Scripts/mount-all-volumes @@ -30,8 +30,8 @@ if __name__ == '__main__': pause("Press Enter to exit...") popen_program(['nohup', 'thunar', '/media'], pipe=True) exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/mount-backup-shares b/.bin/Scripts/mount-backup-shares index 57fbe572..6a1e88d7 100755 --- a/.bin/Scripts/mount-backup-shares +++ b/.bin/Scripts/mount-backup-shares @@ -30,8 +30,8 @@ if __name__ == '__main__': print_standard('\nDone.') #pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/msword-search b/.bin/Scripts/msword-search index b005c3c1..879e6b8d 100755 --- a/.bin/Scripts/msword-search +++ b/.bin/Scripts/msword-search @@ -76,8 +76,8 @@ if __name__ == '__main__': print_standard('\nDone.') #pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/new_system_setup.py b/.bin/Scripts/new_system_setup.py index 9cc93142..68e508d2 100644 --- a/.bin/Scripts/new_system_setup.py +++ b/.bin/Scripts/new_system_setup.py @@ -152,8 +152,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter to exit...') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/safemode_enter.py b/.bin/Scripts/safemode_enter.py index bc6d659d..de9ad119 100644 --- a/.bin/Scripts/safemode_enter.py +++ b/.bin/Scripts/safemode_enter.py @@ -31,8 +31,8 @@ if __name__ == '__main__': pause('Press Enter to reboot...') reboot() exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/safemode_exit.py b/.bin/Scripts/safemode_exit.py index bbbdbcf8..6c47b02d 100644 --- a/.bin/Scripts/safemode_exit.py +++ b/.bin/Scripts/safemode_exit.py @@ -31,8 +31,8 @@ if __name__ == '__main__': pause('Press Enter to reboot...') reboot() exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/sfc_scan.py b/.bin/Scripts/sfc_scan.py index 884694f5..ec85836a 100644 --- a/.bin/Scripts/sfc_scan.py +++ b/.bin/Scripts/sfc_scan.py @@ -32,8 +32,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter to exit...') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/system_checklist.py b/.bin/Scripts/system_checklist.py index d092c8da..a5b86e1e 100644 --- a/.bin/Scripts/system_checklist.py +++ b/.bin/Scripts/system_checklist.py @@ -125,8 +125,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter exit...') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/system_diagnostics.py b/.bin/Scripts/system_diagnostics.py index 47c35eab..b1a1848d 100644 --- a/.bin/Scripts/system_diagnostics.py +++ b/.bin/Scripts/system_diagnostics.py @@ -165,8 +165,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter to exit...') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/transferred_keys.py b/.bin/Scripts/transferred_keys.py index 6dab114d..216f2046 100644 --- a/.bin/Scripts/transferred_keys.py +++ b/.bin/Scripts/transferred_keys.py @@ -21,8 +21,8 @@ if __name__ == '__main__': # Done print_standard('\nDone.') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/update_kit.py b/.bin/Scripts/update_kit.py index 15b3162e..133fe744 100644 --- a/.bin/Scripts/update_kit.py +++ b/.bin/Scripts/update_kit.py @@ -134,8 +134,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/user_checklist.py b/.bin/Scripts/user_checklist.py index e74d26f9..0abd88f3 100644 --- a/.bin/Scripts/user_checklist.py +++ b/.bin/Scripts/user_checklist.py @@ -82,8 +82,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause('Press Enter to exit...') exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/user_data_transfer.py b/.bin/Scripts/user_data_transfer.py index e63e0d7d..60b3c464 100644 --- a/.bin/Scripts/user_data_transfer.py +++ b/.bin/Scripts/user_data_transfer.py @@ -59,8 +59,8 @@ if __name__ == '__main__': print_standard('\nDone.') pause("Press Enter to exit...") exit_script() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception() diff --git a/.bin/Scripts/winpe_root_menu.py b/.bin/Scripts/winpe_root_menu.py index a9555e07..94669609 100644 --- a/.bin/Scripts/winpe_root_menu.py +++ b/.bin/Scripts/winpe_root_menu.py @@ -15,8 +15,8 @@ set_log_file('WinPE.log') if __name__ == '__main__': try: menu_root() - except SystemExit: - pass + except SystemExit as sys_exit: + exit_script(sys_exit.code) except: major_exception()