#!/usr/bin/env python3 """ This mirror status checker determines whether CSC mirror is up-to-date with upstream """ import time import sys import requests from projects import * import json if __name__ == "__main__": exit_code = 0 with open("data.json", "r", encoding="utf-8") as file: data = json.load(file) if sys.stdin.isatty(): projects = data else: projects = [project.rstrip() for project in sys.stdin.readlines()] current_time = int(time.time()) for project in projects: try: if project not in data: print(f"Failure: {project} does not exist") continue project_class = getattr(sys.modules[__name__], project) # Skip projects we no longer mirror if project in ["pkgsrc", "qtproject", "DebianPorts", "OpenBSD"]: continue if project in ["CPAN", "ubuntu", "ubuntu_releases", "manjaro", "mxlinux", "cran", "ctan", "gentooportage"]: checker_result = project_class.check(data, project, current_time) if checker_result: print(f"Success: {project} up-to-date") else: print(f"Failure: {project} out-of-sync") # Exit with non-zero status if any of the projects are not up-to-date exit_code = 1 continue checker_result = project_class.check(data, project, current_time) if checker_result: data[project]["out_of_sync_since"] = None elif data[project]["out_of_sync_since"] is None: data[project]["out_of_sync_since"] = current_time elif current_time - data[project]["out_of_sync_since"] \ > data[project]["out_of_sync_interval"]: print(f"Failure: {project} out-of-sync") # Exit with non-zero status if any of the projects are not up-to-date exit_code = 1 continue print(f"Success: {project} up-to-date") except requests.exceptions.RequestException as err: print(f"Error: {project}\n{err}") with open("data.json", "w", encoding="utf-8") as file: json.dump(data, file, indent='\t') sys.exit(exit_code)