def cleanup(mountpoint, tc_mountpoint, tempdir, value_from_argparser): try: cleanupLogger = ParaLogger("cleanup") parser = configtransport() # # Unmounting Truecrypt # try: if os.path.exists(tc_mountpoint) and os.path.ismount(tc_mountpoint): cleanupLogger.info("Unmounting Truecrypt Container") cleanupLogger.debug("UNMOUNT COMMAND: " + parser.get("truecrypting", "unmount")) subprocess.check_call(shlex.split(parser.get("truecrypting", "unmount"))) except OSError: cleanupLogger.error("Could not unmount tc container on {}").format(tc_mountpoint) cleanupLogger.exception("Could not unmount tc container on {}").format(tc_mountpoint) # # Unmounting USB-Stick # try: if value_from_argparser and os.path.exists(mountpoint) and os.path.ismount(mountpoint) is True: cleanupLogger.info("Unmounting USB-Stick") if sys.platform == "darwin": subprocess.check_call(["diskutil", "eject", mountpoint]) else: subprocess.check_call(["umount", mountpoint]) except OSError: cleanupLogger.error("Could not umount {}").format(mountpoint) cleanupLogger.exception("Could not umount {}").format(mountpoint) # # Removing Temporary Directories # cleanupLogger.info("Cleaning up Temporary Directories") try: if value_from_argparser and os.path.exists(mountpoint) and os.path.ismount(mountpoint) is False: shutil.rmtree(mountpoint) if os.path.exists(tc_mountpoint) and os.path.ismount(tc_mountpoint) is False: shutil.rmtree(tc_mountpoint) if (sys.platform == "darwin") and os.path.exists(tempdir + "/dmg") and os.path.ismount(tempdir + "/dmg"): subprocess.check_call(["diskutil", "eject", os.path.join(tempdir + "/dmg/")]) elif os.path.exists(tempdir + "/dmg") and os.path.ismount(tempdir + "/dmg"): subprocess.check_call(["umount", os.path.join(tempdir + "/dmg/")]) if os.path.exists(tempdir): shutil.rmtree(tempdir) except OSError: cleanupLogger.error("Some temporary Directories could not be removed") cleanupLogger.exception("Some temporary Directories could not be removed") except KeyboardInterrupt: cleanupLogger.error("You've hit Strg+C for interrupting Parabird. Now clean up your own mess. Exiting...") sys.exit()
def cleanup(mountpoint, tc_mountpoint, tempdir, value_from_argparser): try: cleanupLogger = ParaLogger('cleanup') parser = configtransport() # # Unmounting Truecrypt # try: if os.path.exists(tc_mountpoint) and os.path.ismount(tc_mountpoint): cleanupLogger.info("Unmounting Truecrypt Container") cleanupLogger.debug('UNMOUNT COMMAND: ' + parser.get('truecrypting', 'unmount')) subprocess.check_call(shlex.split(parser.get('truecrypting', 'unmount'))) except OSError: cleanupLogger.error("Could not unmount tc container on {}").format(tc_mountpoint) cleanupLogger.exception("Could not unmount tc container on {}").format(tc_mountpoint) # # Unmounting USB-Stick # try: if value_from_argparser and os.path.exists(mountpoint) and os.path.ismount(mountpoint) is True: cleanupLogger.info("Unmounting USB-Stick") if (sys.platform == "darwin"): subprocess.check_call(['diskutil', 'eject', mountpoint]) else: subprocess.check_call(["umount", mountpoint]) except OSError: cleanupLogger.error("Could not umount {}").format(mountpoint) cleanupLogger.exception("Could not umount {}").format(mountpoint) # # Removing Temporary Directories # cleanupLogger.info("Cleaning up Temporary Directories") try: if value_from_argparser and os.path.exists(mountpoint) and os.path.ismount(mountpoint) is False: shutil.rmtree(mountpoint) if os.path.exists(tc_mountpoint) and os.path.ismount(tc_mountpoint) is False: shutil.rmtree(tc_mountpoint) if (sys.platform == "darwin") and os.path.exists(tempdir+"/dmg") and os.path.ismount(tempdir+"/dmg"): subprocess.check_call(['diskutil', 'eject', os.path.join(tempdir+"/dmg/")]) elif os.path.exists(tempdir+"/dmg") and os.path.ismount(tempdir+"/dmg"): subprocess.check_call(['umount', os.path.join(tempdir+"/dmg/")]) if os.path.exists(tempdir): shutil.rmtree(tempdir) except OSError: cleanupLogger.error("Some temporary Directories could not be removed") cleanupLogger.exception("Some temporary Directories could not be removed") except KeyboardInterrupt: cleanupLogger.error("You've hit Strg+C for interrupting Parabird. Now clean up your own mess. Exiting...") sys.exit()
def cleanup(mountpoint, tc_mountpoint, tempdir): mainLogger=ParaLogger('main') parser = configtransport() clparser = argparse.ArgumentParser() clparser = argparse.ArgumentParser(description='') clparser.add_argument("-d", "--device", help="Device Flag to specify USB Stick") args = clparser.parse_args() # # Unmounting Truecrypt # try: if os.path.exists(tc_mountpoint) and os.path.ismount(tc_mountpoint): mainLogger.info("Unmounting Truecrypt Container") mainLogger.debug('UNMOUNT COMMAND: ' + parser.get('truecrypting', 'unmount')) subprocess.check_call(shlex.split(parser.get('truecrypting', 'unmount'))) except OSError: mainLogger.error("Could not unmount tc container on {}").format(tc_mountpoint) mainLogger.exception("Could not unmount tc container on {}").format(tc_mountpoint) # # Unmounting USB-Stick # try: if args.device and os.path.exists(mountpoint) and os.path.ismount(mountpoint) == True: mainLogger.info("Unmounting USB-Stick") if (sys.platform == "darwin"): subprocess.check_call(['diskutil', 'eject', mountpoint]) else: subprocess.check_call(["umount", mountpoint]) except OSError: mainLogger.error("Could not umount {}").format(mountpoint) mainLogger.exception("Could not umount {}").format(mountpoint) # # Removing Temporary Directories # mainLogger.info("Cleaning up Temporary Directories") try: if args.device and os.path.exists(mountpoint) and os.path.ismount(mountpoint) == False: shutil.rmtree(mountpoint) if os.path.exists(tc_mountpoint) and os.path.ismount(tc_mountpoint) == False: shutil.rmtree(tc_mountpoint) if (sys.platform == "darwin") and if os.path.exists(tempdir+"/dmg"): subprocess.check_call(['diskutil', 'eject', os.path.join(tempdir+"/dmg/")]) else: subprocess.check_call(['umount', os.path.join(tempdir+"/dmg/")]) if os.path.exists(tempdir): shutil.rmtree(tempdir) except OSError: mainLogger.error("Some temporary Directories could not be removed") mainLogger.exception("Some temporary Directories could not be removed")
get_extension_id, copy_from_cache, configtransport, suite, update_config, ) from extract_files import extract_tarfile, extract_zipfile from cleanup import cleanup, cleanup_failed try: # # getting the config # parser = configtransport() # # Creation of tempdirs. # tempdir = os.path.realpath(tempfile.mkdtemp()) parser.set("DEFAULT", "tempdir", tempdir) tc_mountpoint = os.path.realpath(tempfile.mkdtemp()) logfile = os.path.realpath(tempdir + "/" + "parabirdy_log.txt") mainLogger = ParaLogger("main") # # Configuring Commandline Arguments and Config
_| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _| _|_|_| Authors: Jakob Hasselmann Jonas Osswald Licence: GPLv3 Follow on Twitter: @jafeha Download: https://github.com/jafeha/parabird ''') # #getting the config # parser = configtransport() # # Creation of tempdirs. # tempdir = os.path.realpath(tempfile.mkdtemp()) parser.set('DEFAULT', 'tempdir', tempdir) tc_mountpoint = os.path.realpath(tempfile.mkdtemp()) logfile = os.path.realpath(tempdir + "/" + "parabirdy_log.txt") mainLogger = ParaLogger('main') # # Configuring Commandline Arguments and Config