feature(backups): job progress logs

This commit is contained in:
Houkime 2023-05-17 18:36:39 +00:00
parent ddd2176a5d
commit 60806cd536

View file

@ -133,18 +133,27 @@ class Jobs:
@staticmethod @staticmethod
def log_status_update(job: Job, status: JobStatus): def log_status_update(job: Job, status: JobStatus):
redis = RedisPool().get_connection() redis = RedisPool().get_connection()
key = _redis_log_key_from_uuid(job.uid) key = _status_log_key_from_uuid(job.uid)
if redis.exists(key): if redis.exists(key):
assert redis.type(key) == "list" assert redis.type(key) == "list"
redis.lpush(key, status.value) redis.lpush(key, status.value)
redis.expire(key, 10) redis.expire(key, 10)
@staticmethod
def log_progress_update(job: Job, progress: int):
redis = RedisPool().get_connection()
key = _progress_log_key_from_uuid(job.uid)
if redis.exists(key):
assert redis.type(key) == "list"
redis.lpush(key, progress)
redis.expire(key, 10)
@staticmethod @staticmethod
def status_updates(job: Job) -> typing.List[JobStatus]: def status_updates(job: Job) -> typing.List[JobStatus]:
result = [] result = []
redis = RedisPool().get_connection() redis = RedisPool().get_connection()
key = _redis_log_key_from_uuid(job.uid) key = _status_log_key_from_uuid(job.uid)
if not redis.exists(key): if not redis.exists(key):
return [] return []
@ -156,6 +165,23 @@ class Jobs:
raise ValueError("impossible job status: " + status) from e raise ValueError("impossible job status: " + status) from e
return result return result
@staticmethod
def progress_updates(job: Job) -> typing.List[int]:
result = []
redis = RedisPool().get_connection()
key = _progress_log_key_from_uuid(job.uid)
if not redis.exists(key):
return []
progress_strings = redis.lrange(key, 0, -1)
for progress in progress_strings:
try:
result.append(int(progress))
except KeyError as e:
raise ValueError("impossible job progress: " + progress) from e
return result
@staticmethod @staticmethod
def update( def update(
job: Job, job: Job,
@ -178,6 +204,7 @@ class Jobs:
job.status_text = status_text job.status_text = status_text
if progress is not None: if progress is not None:
job.progress = progress job.progress = progress
Jobs.log_progress_update(job, progress)
job.status = status job.status = status
Jobs.log_status_update(job, status) Jobs.log_status_update(job, status)
job.updated_at = datetime.datetime.now() job.updated_at = datetime.datetime.now()
@ -235,10 +262,14 @@ def _redis_key_from_uuid(uuid_string):
return "jobs:" + str(uuid_string) return "jobs:" + str(uuid_string)
def _redis_log_key_from_uuid(uuid_string): def _status_log_key_from_uuid(uuid_string):
return STATUS_LOGS_PREFIX + str(uuid_string) return STATUS_LOGS_PREFIX + str(uuid_string)
def _progress_log_key_from_uuid(uuid_string):
return PROGRESS_LOGS_PREFIX + str(uuid_string)
def _store_job_as_hash(redis, redis_key, model): def _store_job_as_hash(redis, redis_key, model):
for key, value in model.dict().items(): for key, value in model.dict().items():
if isinstance(value, uuid.UUID): if isinstance(value, uuid.UUID):