""" * Author: "PeppermintOS Team(peppermintosteam@proton.me) * * License: SPDX-License-Identifier: GPL-3.0-or-later * * Build the ISOs for the the system """ import os from pathlib import Path import argparse import collections import logging import conf import infra import inflate_bubble import finish_cleanup # Set the home path used regardless the user logged in BSTRING_ISO_CONFIGS = '~/bubbles/iso_configs' HOME_FOLDER = str(Path(BSTRING_ISO_CONFIGS).expanduser()) FUSATO_ROOT = '/fusato' WPCHROOT = '/fusato/config/includes.chroot' # Set up the logging format logger = logging.getLogger() handler = logging.StreamHandler() formatter = logging.Formatter( '%(asctime)s %(name)-12s %(levelname)-8s %(message)s') handler.setFormatter(formatter) logger.addHandler(handler) logger.setLevel(logging.DEBUG) # Common Logging Messages CFG_TREE_READY = "Config tree ready!" CFG_READY = "Configs in place start the ISO build process" START_LIVEBUILD = "Start Live-Build Process" BUILD_COMPLETED = "ISO build has completed successfully" BUILD_COMPLETED = "ISO is ready for usage." class BuildXfce: """ Determine what base to use and then build the ISO """ def __init__(self, sbase, sarch): self.sbase = sbase self.sarch = sarch os.chdir(HOME_FOLDER + FUSATO_ROOT) # Determine what base to build if sbase == "deb": # Run the Debian Build self.debian_build() elif sbase == "dev": self.devuan_build() else: print("No base has been found") def debian_build(self): """ Used to build the Debian base XFCE ISO """ if self.sarch == '_64': self.build_deb_64() elif self.sarch == '_32': self.build_deb_32() elif self.sarch == '_arm': self.build_deb_arm() else: logger.warning("No active build specified!") def build_deb_64(self): """ Builds the 64bit ISO XFCE""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory logger.info("Building a " + self.sbase + self.sarch[1:] + " bit ISO") logger.info(dir_current) # Set the config tree bit_arch = self.sarch[1:] if bit_arch == 64: lbsetup = conf.LBSET_DEB64 elif bit_arch == 32: lbsetup = conf.LBSET_DEB32 elif bit_arch == "arm": lbsetup = conf.LBSET_DEBARM else: lbsetup = None os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the XFCE stuff if bit_arch == 64: cmd_list = collections.deque(conf.build64_xfce_build) elif bit_arch == 32: cmd_list = collections.deque(conf.build32_xfce_build) elif bit_arch == "arm": cmd_list = collections.deque(conf.buildarm_xfce_build) else: cmd_list = None list_size = len(cmd_list) for _ in range(list_size): i = cmd_list.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders(self.sbase, self.sarch) infra.BinaryFolders(self.sbase, self.sarch) infra.ArchitectureFiles(self.sbase, self.sarch) infra.Archive(self.sbase, self.sarch) # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_xfce(self.sbase, self.sarch[1:]) logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_debian_xfce_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def build_deb_32(self): """ Builds the 32bit ISO XFCE""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory logger.info("Building a Debian based 32 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEB32 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the XFCE stuff cmd_list_32 = collections.deque(conf.build32_xfce_build) list_size_32 = len(cmd_list_32) for _ in range(list_size_32): i = cmd_list_32.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("deb", "_32") infra.BinaryFolders("deb", "_32") infra.ArchitectureFiles("deb", "_32") infra.Archive("deb", "_32") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEB32 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_xfce("deb", "32") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_debian_xfce_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def build_deb_arm(self): """ Builds the arm ISO XFCE""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory logger.info("Building a Debian based arm bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEBARM os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the XFCE stuff cmd_list_arm = collections.deque(conf.buildarm_xfce_build) list_size_arm = len(cmd_list_arm) for _ in range(list_size_arm): i = cmd_list_arm.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("deb", "_arm") infra.BinaryFolders("deb", "_arm") infra.ArchitectureFiles("deb", "_arm") infra.Archive("deb", "_arm") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEBARM os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_xfce("deb", "arm") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_debian_xfce_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def build_dev_64(self): """ Builds the 64bit ISO XFCE""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory logger.info("Building a devuan based 64 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEV64 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the XFCE stuff cmd_list_64 = collections.deque(conf.build64_xfce_build) list_size_64 = len(cmd_list_64) for _ in range(list_size_64): i = cmd_list_64.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("dev", "_64") infra.BinaryFolders("dev", "_64") infra.ArchitectureFiles("dev", "_64") infra.Archive("dev", "_64") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEV64 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_xfce("dev","64") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_devuan_xfce_based() finish_cleanup.kill_old_iso() #'finish_cleanup.copy_iso_file_prod_deb64', logger.info(BUILD_COMPLETED) def build_dev_32(self): """ Builds the 32bit ISO XFCE""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory logger.info("Building a devuan based 32 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEV32 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the XFCE stuff cmd_list_32 = collections.deque(conf.build32_xfce_build) list_size_32 = len(cmd_list_32) for _ in range(list_size_32): i = cmd_list_32.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("dev", "_32") infra.BinaryFolders("dev", "_32") infra.ArchitectureFiles("dev", "_32") infra.Archive("dev", "_32") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEV32 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_xfce("dev","32") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_devuan_xfce_based() finish_cleanup.kill_old_iso() #'finish_cleanup.copy_iso_file_prod_deb32', logger.info(BUILD_COMPLETED) def build_dev_arm(self): """ Builds the arm ISO XFCE""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory print("INFO: Building a devuan based arm bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEVARM os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the XFCE stuff cmd_list_arm = collections.deque(conf.buildarm_xfce_build) list_size_arm = len(cmd_list_arm) for _ in range(list_size_arm): i = cmd_list_arm.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("dev", "_arm") infra.BinaryFolders("dev", "_arm") infra.ArchitectureFiles("dev", "_arm") infra.Archive("dev", "_arm") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEVARM os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_xfce("dev","arm") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_devuan_xfce_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def devuan_build(self): """ Used to build the devuan base XFCE ISO """ if self.sarch == '_64': self.build_dev_64() elif self.sarch == '_32': self.build_dev_32() elif self.sarch == '_arm': self.build_dev_arm() else: print("WARNING: No active build specified") class BuildGflashback: """ Determine what base to use and then build the ISO """ def __init__(self, sbase, sarch): self.sbase = sbase self.sarch = sarch os.chdir(HOME_FOLDER + FUSATO_ROOT) # Determine what base to build if sbase == "deb": # Run the Debian Build self.debian_build() elif sbase == "dev": self.devuan_build() else: print("No base has been found") def build_deb_64(self): """ Builds the 64bit ISO GNOME FlashBack""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory logger.info("Building a Debian based 64 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEB64 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the GNOME FlashBack stuff cmd_list_64 = collections.deque(conf.build64_gfb_build) list_size_64 = len(cmd_list_64) for _ in range(list_size_64): i = cmd_list_64.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("deb", "_64") infra.BinaryFolders("deb", "_64") infra.ArchitectureFiles("deb", "_64") infra.Archive("deb", "_64") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEB64 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_gnomeflashback("deb","64") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_debian_gfb_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def build_deb_32(self): """ Builds the 32bit ISO GNOME FlashBack""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory print("INFO: Building a Debian based 32 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEB32 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the GNOME FlashBack stuff cmd_list_32 = collections.deque(conf.build32_gfb_build) list_size_32 = len(cmd_list_32) for _ in range(list_size_32): i = cmd_list_32.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("deb", "_32") infra.BinaryFolders("deb", "_32") infra.ArchitectureFiles("deb", "_32") infra.Archive("deb", "_32") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEB32 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_gnomeflashback("deb","32") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_debian_gfb_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def build_deb_arm(self): """ Builds the arm ISO GNOME FlashBack""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory print("INFO: Building a Debian based arm bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEBARM os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the GNOME FlashBack stuff cmd_list_arm = collections.deque(conf.buildarm_gfb_build) list_size_arm = len(cmd_list_arm) for _ in range(list_size_arm): i = cmd_list_arm.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("deb", "_arm") infra.BinaryFolders("deb", "_arm") infra.ArchitectureFiles("deb", "_arm") infra.Archive("deb", "_arm") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEBARM os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_gnomeflashback("deb","arm") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_debian_gfb_based() finish_cleanup.kill_old_iso() logger.info(BUILD_COMPLETED) def debian_build(self): """ Used to build the Debian base GNOME FlashBack ISO """ if self.sarch == '_64': self.build_deb_64() elif self.sarch == '_32': self.build_deb_32() elif self.sarch == '_arm': self.build_deb_arm() else: print("WARNING: No active build specified") def build_dev_64(self): """ Builds the 64bit ISO GNOME FlashBack""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory print("INFO: Building a devuan based 64 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEV64 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the GNOME FlashBack stuff cmd_list_64 = collections.deque(conf.build64_gfb_build) list_size_64 = len(cmd_list_64) for _ in range(list_size_64): i = cmd_list_64.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("dev", "_64") infra.BinaryFolders("dev", "_64") infra.ArchitectureFiles("dev", "_64") infra.Archive("dev", "_64") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEV64 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_gnomeflashback("dev","64") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_devuan_gfb_based() finish_cleanup.kill_old_iso() #'finish_cleanup.copy_iso_file_prod_deb64', logger.info(BUILD_COMPLETED) def build_dev_32(self): """ Builds the 32bit ISO GNOME FlashBack""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory print("INFO: Building a devuan based 32 bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEV32 os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the GNOME FlashBack stuff cmd_list_32 = collections.deque(conf.build32_gfb_build) list_size_32 = len(cmd_list_32) for _ in range(list_size_32): i = cmd_list_32.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("dev", "_32") infra.BinaryFolders("dev", "_32") infra.ArchitectureFiles("dev", "_32") infra.Archive("dev", "_32") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEV32 os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_gnomeflashback("dev","32") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_devuan_gfb_based() finish_cleanup.kill_old_iso() #'finish_cleanup.copy_iso_file_prod_deb32', logger.info(BUILD_COMPLETED) def build_dev_arm(self): """ Builds the arm ISO GNOME FlashBack""" current_working_directory = os.getcwd() dir_current = "Current working directory" + current_working_directory print("INFO: Building a devuan based arm bit ISO") logger.info(dir_current) # Set the config tree lbsetup = conf.LBSET_DEVARM os.system(lbsetup) logger.info(CFG_TREE_READY) # Start with the GNOME FlashBack stuff cmd_list_arm = collections.deque(conf.buildarm_gfb_build) list_size_arm = len(cmd_list_arm) for _ in range(list_size_arm): i = cmd_list_arm.popleft() execute = i + '()' exec(execute) # Run the specific classes infra.ChrootFolders("dev", "_arm") infra.BinaryFolders("dev", "_arm") infra.ArchitectureFiles("dev", "_arm") infra.Archive("dev", "_arm") # Run the Build logger.info(CFG_READY) logger.info(START_LIVEBUILD) logger.info(dir_current) lbsetup = conf.LBSET_DEVARM os.system(lbsetup) run_cmd = 'sudo lb build' current_working_directory = os.getcwd() os.chdir(HOME_FOLDER + FUSATO_ROOT) # Set the build inidcator inflate_bubble.make_bld_gnomeflashback("dev", "arm") logger.info(dir_current) os.system(run_cmd) logger.info(BUILD_COMPLETED) logger.info(dir_current) finish_cleanup.make_check_sum() finish_cleanup.copy_devuan_gfb_based() finish_cleanup.kill_old_iso() #'finish_cleanup.copy_iso_file_prod_DEBARM', logger.info(BUILD_COMPLETED) def devuan_build(self): """ Used to build the devuan base GNOME FlashBack ISO """ if self.sarch == '_64': self.build_dev_64() elif self.sarch == '_32': self.build_dev_32() elif self.sarch == '_arm': self.build_dev_arm() else: print("WARNING: No active build specified") def readybuild(): """" Make Ready the bld structure If fusato exists remove it. and recreate it, otherwise just make a new folder named fusato. """ logger.info("Making ready the fusato build directory") os.chdir(HOME_FOLDER) if os.path.exists('fusato'): rm_cmd = "sudo rm -r -f fusato" os.system(rm_cmd) os.makedirs('fusato') else: os.makedirs('fusato') class Decsions: """ Aguments used to tell the application what to build """ def __init__(self): # Set up the terminal arguments self.argument_parser = argparse.ArgumentParser() self.argument_parser.add_argument("set", help="set what build to start", type=str ) self.argument_parser.add_argument("e", help="identify the desktop" " environment for example" " e-xfce", type=str ) self.argument_parser.add_argument("b", help="identify the ISO to" "build for example" " b-deb64", type=str ) self.arguments = self.argument_parser.parse_args() # Then determine what desktop build to look for if self.arguments.e == 'e-gnomefb': self.dgnomefb() elif self.arguments.e == 'e-xfce': self.dxfce() elif self.arguments.e == 'e-openbox': self.dopenbox() def dxfce(self): """ Arguments for the XFCE """ if self.arguments.e == 'e-xfce': if self.arguments.b == 'b-deb64': readybuild() BuildXfce("deb", "_64") elif self.arguments.b == 'b-deb32': readybuild() BuildXfce("deb", "_32") elif self.arguments.b == 'b-dev64': readybuild() BuildXfce("dev", "_64") elif self.arguments.b == 'b-dev32': readybuild() BuildXfce("dev", "_32") elif self.arguments.b == 'b-debarm': readybuild() BuildXfce("deb", "_arm") elif self.arguments.b == 'b-devarm': readybuild() BuildXfce("dev", "_arm") else: logger.critical("You have not specified a build to process!") def dgnomefb(self): """ Arguments for the gnomefb """ if self.arguments.e == 'e-gnomefb': if self.arguments.b == 'b-deb64': readybuild() BuildGflashback("deb", "_64") elif self.arguments.b == 'b-deb32': readybuild() BuildGflashback("deb", "_32") elif self.arguments.b == 'b-debarm': readybuild() BuildGflashback("deb", "_arm") elif self.arguments.b == 'b-dev32': readybuild() BuildGflashback("dev", "_32") elif self.arguments.b == 'b-dev64': readybuild() BuildGflashback("dev", "_64") elif self.arguments.b == 'b-devarm': readybuild() BuildGflashback("dev", "_arm") else: logger.critical("You have not specified a build to process!") def dopenbox(self): """ Arguments for the openbox """ if self.arguments.e == 'e-openbox': if self.arguments.b == 'b-deb64': readybuild() print('run openbox builds deb64') elif self.arguments.b == 'b-deb32': readybuild() print('run openbox builds deb32') elif self.arguments.b == 'b-dev64': readybuild() print('run openbox builds dev64') elif self.arguments.b == 'b-dev32': readybuild() print('run openbox builds dev32') elif self.arguments.b == 'b-debarm': readybuild() print('run openbox builds debarm') elif self.arguments.b == 'b-devarm': readybuild() print('run openbox builds devarm') else: print('You have not specified a valid ' 'build architecture!!') else: logger.critical("You have not specified a valid " "desktop environment!!") Decsions()