mirror of
https://gitlab.com/crafty-controller/crafty-4.git
synced 2025-01-19 17:55:29 +01:00
112 lines
3.6 KiB
Python
112 lines
3.6 KiB
Python
import os
|
|
import shutil
|
|
import sys
|
|
import logging
|
|
import pathlib
|
|
|
|
from app.classes.shared.console import console
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
try:
|
|
from zipfile import ZipFile, ZIP_DEFLATED
|
|
|
|
except ModuleNotFoundError as err:
|
|
logger.critical(f"Import Error: Unable to load {err.name} module", exc_info=True)
|
|
console.critical(f"Import Error: Unable to load {err.name} module")
|
|
sys.exit(1)
|
|
|
|
class FileHelpers:
|
|
allowed_quotes = [
|
|
"\"",
|
|
"'",
|
|
"`"
|
|
]
|
|
|
|
def del_dirs(self, path):
|
|
path = pathlib.Path(path)
|
|
for sub in path.iterdir():
|
|
if sub.is_dir():
|
|
# Delete folder if it is a folder
|
|
self.del_dirs(sub)
|
|
else:
|
|
# Delete file if it is a file:
|
|
sub.unlink()
|
|
|
|
# This removes the top-level folder:
|
|
path.rmdir()
|
|
return True
|
|
|
|
@staticmethod
|
|
def del_file(path):
|
|
path = pathlib.Path(path)
|
|
try:
|
|
logger.debug(f"Deleting file: {path}")
|
|
#Remove the file
|
|
os.remove(path)
|
|
return True
|
|
except FileNotFoundError:
|
|
logger.error(f"Path specified is not a file or does not exist. {path}")
|
|
return False
|
|
|
|
@staticmethod
|
|
def copy_dir(src_path, dest_path, dirs_exist_ok=False):
|
|
# pylint: disable=unexpected-keyword-arg
|
|
shutil.copytree(src_path, dest_path, dirs_exist_ok=dirs_exist_ok)
|
|
|
|
@staticmethod
|
|
def copy_file(src_path, dest_path):
|
|
shutil.copy(src_path, dest_path)
|
|
|
|
def move_dir(self, src_path, dest_path):
|
|
self.copy_dir(src_path, dest_path)
|
|
self.del_dirs(src_path)
|
|
|
|
def move_file(self, src_path, dest_path):
|
|
self.copy_file(src_path, dest_path)
|
|
self.del_file(src_path)
|
|
|
|
@staticmethod
|
|
def make_archive(path_to_destination, path_to_zip):
|
|
# create a ZipFile object
|
|
path_to_destination += '.zip'
|
|
with ZipFile(path_to_destination, 'w') as z:
|
|
for root, _dirs, files in os.walk(path_to_zip, topdown=True):
|
|
ziproot = path_to_zip
|
|
for file in files:
|
|
try:
|
|
logger.info(f"backing up: {os.path.join(root, file)}")
|
|
if os.name == "nt":
|
|
z.write(os.path.join(root, file), os.path.join(root.replace(ziproot, ""), file))
|
|
else:
|
|
z.write(os.path.join(root, file), os.path.join(root.replace(ziproot, "/"), file))
|
|
|
|
except Exception as e:
|
|
logger.warning(f"Error backing up: {os.path.join(root, file)}! - Error was: {e}")
|
|
|
|
|
|
return True
|
|
|
|
@staticmethod
|
|
def make_compressed_archive(path_to_destination, path_to_zip):
|
|
# create a ZipFile object
|
|
path_to_destination += '.zip'
|
|
with ZipFile(path_to_destination, 'w', ZIP_DEFLATED) as z:
|
|
for root, _dirs, files in os.walk(path_to_zip, topdown=True):
|
|
ziproot = path_to_zip
|
|
for file in files:
|
|
try:
|
|
logger.info(f"backing up: {os.path.join(root, file)}")
|
|
if os.name == "nt":
|
|
z.write(os.path.join(root, file), os.path.join(root.replace(ziproot, ""), file))
|
|
else:
|
|
z.write(os.path.join(root, file), os.path.join(root.replace(ziproot, "/"), file))
|
|
|
|
except Exception as e:
|
|
logger.warning(f"Error backing up: {os.path.join(root, file)}! - Error was: {e}")
|
|
|
|
|
|
return True
|
|
|
|
file_helper = FileHelpers()
|