mirror-checker/main.py

73 lines
2.0 KiB
Python
Raw Normal View History

2021-08-16 18:23:04 -04:00
#!/usr/bin/env python3
"""
This mirror status checker determines whether CSC mirror is up-to-date with upstream
"""
2021-09-01 23:25:06 -04:00
import time
import sys
2021-08-16 18:23:04 -04:00
import requests
from multiprocessing import Pool, Manager
2021-10-03 16:43:06 -04:00
2021-10-17 23:50:21 -04:00
from projects import *
import json
2021-10-03 15:35:17 -04:00
NUM_THREAD = 16
current_time = int(time.time())
2021-08-19 17:00:55 -04:00
2022-01-06 12:51:04 -05:00
def safe_print(*args, **kwargs):
# When run with 'chronic' and 'timeout', stdout gets suppressed
# due to buffering. Make sure to always flush the output.
print(*args, **kwargs, flush=True)
def check_project(args):
project, data = args
try:
project_class = getattr(sys.modules[__name__], project)
2022-01-06 12:51:04 -05:00
# Skip projects we no longer mirror
if data[project].get('exclude', False):
return True
checker_result = project_class.check(data, project, current_time)
if checker_result:
data[project]["out_of_sync_since"] = None
safe_print(f"Success: {project} up-to-date")
return True
elif (data[project]["out_of_sync_since"] is not None
and current_time - data[project]["out_of_sync_since"] > data[project]["out_of_sync_interval"]):
safe_print(f"Failure: {project} out-of-sync")
return False
else:
data[project]["out_of_sync_since"] = current_time
return True
2021-09-01 23:25:06 -04:00
except requests.exceptions.RequestException as err:
safe_print(f"Error: {project}\n{err}")
2022-01-05 20:16:35 -05:00
return False
def main():
2022-01-05 20:16:35 -05:00
data_file = 'data.json'
if len(sys.argv) > 1:
data_file = sys.argv[1]
manager = Manager()
2022-01-05 20:16:35 -05:00
data = json.load(open(data_file))
sync_data = manager.dict({k: manager.dict(v) for k, v in data.items()})
with Pool(NUM_THREAD) as pool:
all_pass = all(pool.imap(check_project, ((k, sync_data) for k in data.keys())))
2022-01-05 20:16:35 -05:00
with open(data_file, "w", encoding="utf-8") as file:
json.dump({k: dict(v) for k, v in sync_data.items()}, file, indent=' ')
sys.exit(0 if all_pass else 1)
2022-01-05 20:16:35 -05:00
if __name__ == "__main__":
main()