69 lines
2.3 KiB
Python
Executable File
69 lines
2.3 KiB
Python
Executable File
import paramiko
|
|
import sys
|
|
import json
|
|
import logging
|
|
import unicodedata
|
|
logging.basicConfig(
|
|
format='%(asctime)s %(levelname)-8s %(message)s',
|
|
level=logging.INFO,
|
|
datefmt='%Y-%m-%d %H:%M:%S'
|
|
)
|
|
|
|
def create_remote(config, settings):
|
|
type_r = config["remote_type"]
|
|
if type_r == "sftp":
|
|
import remote_sftp
|
|
remote = remote_sftp.sftp_remote(config, settings)
|
|
elif type_r == "local_dir":
|
|
import remote_local_dir
|
|
remote = remote_local_dir.local_dir_remote(config)
|
|
return remote
|
|
|
|
def distribute_files(path_list, dest):
|
|
for pathfile in path_list:
|
|
if not str(pathfile).endswith('.dem'):
|
|
continue
|
|
log_msg = "uploading demo: " + str(pathfile)
|
|
logging.info(log_msg)
|
|
if not dest.put(pathfile, dest.path):
|
|
log_msg = ''.join(["failed putting file: ", str(pathfile)])
|
|
logging.warning(log_msg)
|
|
sys.exit(1)
|
|
|
|
def load_config(config_file):
|
|
try:
|
|
with open(config_file) as infile:
|
|
try:
|
|
json_dict = json.load(infile)
|
|
#logging.info(json_dict)
|
|
return json_dict["remotes"], json_dict["jobs"], json_dict["settings"]
|
|
except json.JSONDecodeError as e:
|
|
logging.warning('exception caught: ', exc_info = True)
|
|
sys.exit(1)
|
|
except FileNotFoundError:
|
|
logging.warning('exception caught: ', exc_info = True)
|
|
sys.exit(1)
|
|
|
|
def main():
|
|
#runs demos every 5 minutes but backups thrice a week with systemctl services/timers
|
|
config_file = 'config_demos.json'
|
|
if sys.argv[1:]:
|
|
config_file = sys.argv[1]
|
|
remotes, jobs, settings = load_config(config_file)
|
|
for job in jobs:
|
|
src = create_remote(remotes[job["src"]], settings)
|
|
dest = create_remote(remotes[job["dest"]], settings)
|
|
if 'demo_' in job["job_name"]:
|
|
source_files = src.list_dir()
|
|
distribute_files(source_files, dest)
|
|
for pathfile in source_files:
|
|
src.delete_local_demo(pathfile)
|
|
dest.delete_remote(source_files)
|
|
elif "backup_local" in job["job_name"]:
|
|
zip_directory_cmd = f'zip -r {job["zipname"]}-{str(datetime.now()).split(" ")[0]}.zip {remotes[job["src"]]["path"]}'
|
|
|
|
logging.info(('finished job: ', job))
|
|
|
|
if __name__ == '__main__':
|
|
main()
|