2022-03-01 01:02:30 +00:00
|
|
|
import os
|
|
|
|
import shutil
|
|
|
|
import logging
|
|
|
|
import pathlib
|
2022-03-08 04:40:44 +00:00
|
|
|
from zipfile import ZipFile, ZIP_DEFLATED
|
2022-03-01 01:02:30 +00:00
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
|
2022-03-01 01:02:30 +00:00
|
|
|
class FileHelpers:
|
2022-03-23 02:50:12 +00:00
|
|
|
allowed_quotes = ['"', "'", "`"]
|
2022-03-01 01:02:30 +00:00
|
|
|
|
|
|
|
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}")
|
2022-03-23 02:50:12 +00:00
|
|
|
# Remove the file
|
2022-03-01 01:02:30 +00:00
|
|
|
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
|
2022-03-23 02:50:12 +00:00
|
|
|
path_to_destination += ".zip"
|
|
|
|
with ZipFile(path_to_destination, "w") as z:
|
2022-03-01 01:02:30 +00:00
|
|
|
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":
|
2022-03-23 02:50:12 +00:00
|
|
|
z.write(
|
|
|
|
os.path.join(root, file),
|
|
|
|
os.path.join(root.replace(ziproot, ""), file),
|
|
|
|
)
|
2022-03-01 01:02:30 +00:00
|
|
|
else:
|
2022-03-23 02:50:12 +00:00
|
|
|
z.write(
|
|
|
|
os.path.join(root, file),
|
|
|
|
os.path.join(root.replace(ziproot, "/"), file),
|
|
|
|
)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
|
|
|
except Exception as e:
|
2022-03-23 02:50:12 +00:00
|
|
|
logger.warning(
|
|
|
|
f"Error backing up: {os.path.join(root, file)}! - Error was: {e}"
|
|
|
|
)
|
2022-03-01 01:02:30 +00:00
|
|
|
|
|
|
|
return True
|
|
|
|
|
2022-03-02 11:34:26 -05:00
|
|
|
@staticmethod
|
|
|
|
def make_compressed_archive(path_to_destination, path_to_zip):
|
|
|
|
# create a ZipFile object
|
2022-03-23 02:50:12 +00:00
|
|
|
path_to_destination += ".zip"
|
|
|
|
with ZipFile(path_to_destination, "w", ZIP_DEFLATED) as z:
|
2022-03-02 11:34:26 -05:00
|
|
|
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":
|
2022-03-23 02:50:12 +00:00
|
|
|
z.write(
|
|
|
|
os.path.join(root, file),
|
|
|
|
os.path.join(root.replace(ziproot, ""), file),
|
|
|
|
)
|
2022-03-02 11:34:26 -05:00
|
|
|
else:
|
2022-03-23 02:50:12 +00:00
|
|
|
z.write(
|
|
|
|
os.path.join(root, file),
|
|
|
|
os.path.join(root.replace(ziproot, "/"), file),
|
|
|
|
)
|
2022-03-02 11:34:26 -05:00
|
|
|
|
|
|
|
except Exception as e:
|
2022-03-23 02:50:12 +00:00
|
|
|
logger.warning(
|
|
|
|
f"Error backing up: {os.path.join(root, file)}! - Error was: {e}"
|
|
|
|
)
|
2022-03-02 11:34:26 -05:00
|
|
|
|
|
|
|
return True
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
|
2022-03-01 01:02:30 +00:00
|
|
|
file_helper = FileHelpers()
|