-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
36 lines (29 loc) · 1.58 KB
/
main.py
File metadata and controls
36 lines (29 loc) · 1.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
from File_synchronizer import Synchronizer
import logging
import threading
import os
from misc.instruments import load_config, check_directory, check_cloud_service_config
def loop(done_param, token, folder, directory, service_object, interval=1):
while not done_param.wait(interval):
Synchronizer(service_object(token, folder), directory).synchronise()
if __name__ == '__main__':
if not os.path.exists('logs'):
os.mkdir('logs')
logging.basicConfig(level=logging.INFO, filename='logs/logs.log', filemode='w', encoding='utf-8',
format='%(asctime)s %(levelname)s %(message)s', datefmt='%Y-%m-%d %H:%M:%S')
config = load_config()
check_directory(config['PARAMS']['local_folder'])
service_class = check_cloud_service_config(config['SERVICE']['service_type'])
done = threading.Event()
logging.info('Запуск программы')
logging.info(f'Директория для отслеживания: {config["PARAMS"]["local_folder"]}')
logging.info(f'Директория для загрузки: {config["PARAMS"]["service_folder"]}')
threading.Thread(target=loop, args=[done,
config['SERVICE']['service_token'],
config['PARAMS']['service_folder'],
config['PARAMS']['local_folder'],
service_class,
int(config['PARAMS']['sync_interval'])],
daemon=True).start()
input('Press Enter to exit.')
done.set()