def clear_thumbs(type=None): from resources.libs import db dialog = xbmcgui.Dialog() thumb_locations = {CONFIG.THUMBNAILS, os.path.join(CONFIG.ADDON_DATA, 'script.module.metadatautils', 'animatedgifs'), os.path.join(CONFIG.ADDON_DATA, 'script.extendedinfo', 'images')} latest = db.latest_db('Textures') if type is not None: choice = 1 else: choice = dialog.yesno(CONFIG.ADDONTITLE, '[COLOR {0}]Le gustaria eliminar {1} y las carpetas de miniaturas relacionadas?'.format(CONFIG.COLOR2, latest) + '\n' + "Ellas se repoblarán en la próxima puesta en marcha.[/COLOR]", nolabel='[B][COLOR red]No Eliminar[/COLOR][/B]', yeslabel='[B][COLOR dodgerblue]Eliminar Pulgares[/COLOR][/B]') if choice == 1: try: tools.remove_file(os.path.join(CONFIG.DATABASE, latest)) except: logging.log('Error al eliminar, Purgando DB.') db.purge_db_file(latest) for i in thumb_locations: tools.remove_folder(i) else: logging.log('Borrar nombres en miniatura cancelados') tools.redo_thumbs()
def clear_thumbs(type=None): from resources.libs import db dialog = xbmcgui.Dialog() thumb_locations = { CONFIG.THUMBNAILS, os.path.join(CONFIG.ADDON_DATA, 'script.module.metadatautils', 'animatedgifs'), os.path.join(CONFIG.ADDON_DATA, 'script.extendedinfo', 'images') } latest = db.latest_db('Textures') if type is not None: choice = 1 else: choice = dialog.yesno( CONFIG.ADDONTITLE, '[COLOR {0}]Would you like to delete the {1} and related thumbnail folders?' .format(CONFIG.COLOR2, latest) + '\n' + "They will repopulate on the next startup[/COLOR]", nolabel='[B][COLOR red]Don\'t Delete[/COLOR][/B]', yeslabel='[B][COLOR springgreen]Delete Thumbs[/COLOR][/B]') if choice == 1: try: tools.remove_file(os.path.join(CONFIG.DATABASE, latest)) except: logging.log('Failed to delete, Purging DB.') db.purge_db_file(latest) for i in thumb_locations: tools.remove_folder(i) else: logging.log('Clear thumbnames cancelled') tools.redo_thumbs()
def clear_thumbs(type=None): from resources.libs import db dialog = xbmcgui.Dialog() thumb_locations = {CONFIG.THUMBNAILS, os.path.join(CONFIG.ADDON_DATA, 'script.module.metadatautils', 'animatedgifs'), os.path.join(CONFIG.ADDON_DATA, 'script.extendedinfo', 'images')} latest = db.latest_db('Textures') if type is not None: choice = 1 else: choice = dialog.yesno(CONFIG.ADDONTITLE, '[COLOR {0}]Você gostaria de excluir o {1} e as pastas de miniaturas relacionadas?'.format(CONFIG.COLOR2, latest) + '\n' + "Eles irão repovoar na próxima inicialização[/COLOR]", nolabel='[B][COLOR red]Não apagar[/COLOR][/B]', yeslabel='[B][COLOR springgreen]Apagar Thumbs[/COLOR][/B]') if choice == 1: try: tools.remove_file(os.path.join(CONFIG.DATABASE, latest)) except: logging.log('Failed to delete, Purging DB.') db.purge_db_file(latest) for i in thumb_locations: tools.remove_folder(i) else: logging.log('Clear thumbnames cancelled') tools.redo_thumbs()
def wipe(): from resources.libs import db from resources.libs.common import logging from resources.libs import skin from resources.libs.common import tools from resources.libs import update if CONFIG.KEEPTRAKT == 'true': from resources.libs import traktit traktit.auto_update('all') CONFIG.set_setting('traktnextsave', str(tools.get_date(days=3, formatted=True))) if CONFIG.KEEPDEBRID == 'true': from resources.libs import debridit debridit.auto_update('all') CONFIG.set_setting('debridnextsave', str(tools.get_date(days=3, formatted=True))) if CONFIG.KEEPLOGIN == 'true': from resources.libs import loginit loginit.auto_update('all') CONFIG.set_setting('loginnextsave', str(tools.get_date(days=3, formatted=True))) exclude_dirs = CONFIG.EXCLUDES exclude_dirs.append('My_Builds') progress_dialog = xbmcgui.DialogProgress() skin.skin_to_default('Fresh Install') update.addon_updates('set') xbmcPath = os.path.abspath(CONFIG.HOME) progress_dialog.create(CONFIG.ADDONTITLE, "[COLOR {0}]Calculating files and folders".format(CONFIG.COLOR2) + '\n' + '\n' + 'Please Wait![/COLOR]') total_files = sum([len(files) for r, d, files in os.walk(xbmcPath)]) del_file = 0 progress_dialog.update(0, "[COLOR {0}]Gathering Excludes list.[/COLOR]".format(CONFIG.COLOR2)) if CONFIG.KEEPREPOS == 'true': repos = glob.glob(os.path.join(CONFIG.ADDONS, 'repo*/')) for item in repos: repofolder = os.path.split(item[:-1])[1] if not repofolder == exclude_dirs: exclude_dirs.append(repofolder) if CONFIG.KEEPSUPER == 'true': exclude_dirs.append('plugin.program.super.favourites') if CONFIG.KEEPWHITELIST == 'true': from resources.libs import whitelist whitelist = whitelist.whitelist('read') if len(whitelist) > 0: for item in whitelist: try: name, id, fold = item except: pass depends = db.depends_list(fold) for plug in depends: if plug not in exclude_dirs: exclude_dirs.append(plug) depends2 = db.depends_list(plug) for plug2 in depends2: if plug2 not in exclude_dirs: exclude_dirs.append(plug2) if fold not in exclude_dirs: exclude_dirs.append(fold) for item in CONFIG.DEPENDENCIES: exclude_dirs.append(item) progress_dialog.update(0, "[COLOR {0}]Clearing out files and folders:".format(CONFIG.COLOR2)) latestAddonDB = db.latest_db('Addons') for root, dirs, files in os.walk(xbmcPath, topdown=True): dirs[:] = [d for d in dirs if d not in exclude_dirs] for name in files: del_file += 1 fold = root.replace('/', '\\').split('\\') x = len(fold)-1 if name == 'sources.xml' and fold[-1] == 'userdata' and CONFIG.KEEPSOURCES == 'true': logging.log("Keep sources.xml: {0}".format(os.path.join(root, name))) elif name == 'favourites.xml' and fold[-1] == 'userdata' and CONFIG.KEEPFAVS == 'true': logging.log("Keep favourites.xml: {0}".format(os.path.join(root, name))) elif name == 'profiles.xml' and fold[-1] == 'userdata' and CONFIG.KEEPPROFILES == 'true': logging.log("Keep profiles.xml: {0}".format(os.path.join(root, name))) elif name == 'playercorefactory.xml' and fold[-1] == 'userdata' and CONFIG.KEEPPLAYERCORE == 'true': logging.log("Keep playercorefactory.xml: {0}".format(os.path.join(root, name))) elif name == 'guisettings.xml' and fold[-1] == 'userdata' and CONFIG.KEEPGUISETTINGS == 'true': logging.log("Keep guisettings.xml: {0}".format(os.path.join(root, name))) elif name == 'advancedsettings.xml' and fold[-1] == 'userdata' and CONFIG.KEEPADVANCED == 'true': logging.log("Keep advancedsettings.xml: {0}".format(os.path.join(root, name))) elif name in CONFIG.LOGFILES: logging.log("Keep Log File: {0}".format(name)) elif name.endswith('.db'): try: if name == latestAddonDB: logging.log("Ignoring {0} on Kodi {1}".format(name, tools.kodi_version())) else: os.remove(os.path.join(root, name)) except Exception as e: if not name.startswith('Textures13'): logging.log('Failed to delete, Purging DB') logging.log("-> {0}".format(str(e))) db.purge_db_file(os.path.join(root, name)) else: progress_dialog.update(int(tools.percentage(del_file, total_files)), '\n' + '[COLOR {0}]File: [/COLOR][COLOR {1}]{2}[/COLOR]'.format(CONFIG.COLOR2, CONFIG.COLOR1, name)) try: os.remove(os.path.join(root, name)) except Exception as e: logging.log("Error removing {0}".format(os.path.join(root, name))) logging.log("-> / {0}".format(str(e))) if progress_dialog.iscanceled(): progress_dialog.close() logging.log_notify(CONFIG.ADDONTITLE, "[COLOR {0}]Fresh Start Cancelled[/COLOR]".format(CONFIG.COLOR2)) return False for root, dirs, files in os.walk(xbmcPath, topdown=True): dirs[:] = [d for d in dirs if d not in exclude_dirs] for name in dirs: progress_dialog.update(100, '\n' + 'Cleaning Up Empty Folder: [COLOR {0}]{1}[/COLOR]'.format(CONFIG.COLOR1, name)) if name not in ["Database", "userdata", "temp", "addons", "addon_data"]: shutil.rmtree(os.path.join(root, name), ignore_errors=True, onerror=None) if progress_dialog.iscanceled(): progress_dialog.close() logging.log_notify(CONFIG.ADDONTITLE, "[COLOR {0}]Fresh Start Cancelled[/COLOR]".format(CONFIG.COLOR2)) return False progress_dialog.close() CONFIG.clear_setting('build')