def exp_rename(old_name, new_name): res = exp_rename.super(old_name, new_name) from_files = file.get_store_path(old_name) to_files = file.get_store_path(new_name) if os.path.exists(from_files) and not os.path.exists(to_files): shutil.copytree(from_files, to_files) return res
def exp_duplicate_database(db_original_name, db_name): res = exp_duplicate_database.super(db_original_name, db_name) from_files = file.get_store_path(db_original_name) to_files = file.get_store_path(db_name) if os.path.exists(from_files) and not os.path.exists(to_files): shutil.copytree(from_files, to_files) return res
def restore_db(db, dump_file, copy=False): res = restore_db.super(db, dump_file, copy) with osutil.tempdir() as dump_dir: if zipfile.is_zipfile(dump_file): with zipfile.ZipFile(dump_file, 'r') as zip: files = [m for m in zip.namelist() if m.startswith('files/')] if files: z.extractall(dump_dir, files) files_path = os.path.join(dump_dir, 'files') shutil.move(files_path, file.get_store_path(db_name)) return res
def dump_db(db_name, stream, backup_format='zip'): if backup_format == 'zip': res = dump_db.super(db_name, False, backup_format) with osutil.tempdir() as dump_dir: with zipfile.ZipFile(res, 'r') as zip: zip.extractall(dump_dir) files = file.get_store_path(db_name) if os.path.exists(files): shutil.copytree(files, os.path.join(dump_dir, 'files')) if stream: osutil.zip_dir(dump_dir, stream, include_dir=False, fnct_sort=lambda file_name: file_name != 'dump.sql') else: t=tempfile.TemporaryFile() osutil.zip_dir(dump_dir, t, include_dir=False, fnct_sort=lambda file_name: file_name != 'dump.sql') t.seek(0) return t else: return dump_db.super(db_name, stream, backup_format)
def exp_drop(db_name): res = exp_drop.super(db_name) files = file.get_store_path(db_name) if os.path.exists(files): shutil.rmtree(files) return res