2021-06-14 22:18:39 +02:00
|
|
|
from django.db import models
|
2022-11-09 13:56:50 -05:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2021-06-14 22:18:39 +02:00
|
|
|
import django.contrib.postgres.fields as postgres
|
|
|
|
from users.models import User
|
2021-08-29 17:52:42 +02:00
|
|
|
from common.utils import GenerateDateUUIDMediaFilePath
|
2022-11-09 13:56:50 -05:00
|
|
|
from django.conf import settings
|
2021-08-29 17:52:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
def sync_file_path(instance, filename):
|
2022-11-09 13:56:50 -05:00
|
|
|
return GenerateDateUUIDMediaFilePath(instance, filename, settings.SYNC_FILE_PATH_ROOT)
|
2021-06-14 22:18:39 +02:00
|
|
|
|
|
|
|
|
|
|
|
class SyncTask(models.Model):
|
|
|
|
"""A class that records information about douban data synchronization task."""
|
|
|
|
|
2021-08-29 17:52:42 +02:00
|
|
|
#-----------------------------------#
|
|
|
|
# basic infos
|
|
|
|
#-----------------------------------#
|
2021-06-14 22:18:39 +02:00
|
|
|
user = models.ForeignKey(
|
|
|
|
User, on_delete=models.CASCADE, related_name='user_%(class)ss')
|
2021-09-01 11:41:21 +02:00
|
|
|
file = models.FileField(upload_to=sync_file_path, default='')
|
2021-08-29 17:52:42 +02:00
|
|
|
|
|
|
|
#-----------------------------------#
|
|
|
|
# options
|
|
|
|
#-----------------------------------#
|
|
|
|
# for the same book, if is already marked before sync, overwrite the previous mark or not
|
|
|
|
overwrite = models.BooleanField(default=False)
|
|
|
|
# sync book marks or not
|
|
|
|
sync_book = models.BooleanField()
|
|
|
|
# sync movie marks or not
|
|
|
|
sync_movie = models.BooleanField()
|
|
|
|
# sync music marks or not
|
|
|
|
sync_music = models.BooleanField()
|
|
|
|
# sync game marks or not
|
|
|
|
sync_game = models.BooleanField()
|
|
|
|
# default visibility of marks
|
|
|
|
default_public = models.BooleanField()
|
|
|
|
|
|
|
|
#-----------------------------------#
|
|
|
|
# execution status
|
|
|
|
#-----------------------------------#
|
2021-06-14 22:18:39 +02:00
|
|
|
is_failed = models.BooleanField(default=False)
|
|
|
|
# fail_reason = models.TextField(default='')
|
|
|
|
is_finished = models.BooleanField(default=False)
|
|
|
|
# how many items to synchronize
|
|
|
|
total_items = models.PositiveIntegerField(default=0)
|
|
|
|
# how many items are handled
|
|
|
|
finished_items = models.PositiveIntegerField(default=0)
|
|
|
|
# how many imtes have been synchronized successfully
|
|
|
|
success_items = models.PositiveIntegerField(default=0)
|
|
|
|
|
|
|
|
failed_urls = postgres.ArrayField(
|
|
|
|
models.URLField(blank=True, default='', max_length=200),
|
|
|
|
null=True,
|
|
|
|
blank=True,
|
|
|
|
default=list,
|
|
|
|
)
|
|
|
|
|
2021-08-29 17:52:42 +02:00
|
|
|
break_point = models.CharField(max_length=100, default="", blank=True)
|
|
|
|
|
2021-06-14 22:18:39 +02:00
|
|
|
started_time = models.DateTimeField(auto_now_add=True)
|
|
|
|
ended_time = models.DateTimeField(auto_now=True)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
"""Meta definition for SyncTask."""
|
|
|
|
|
|
|
|
verbose_name = 'SyncTask'
|
|
|
|
verbose_name_plural = 'SyncTasks'
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
"""Unicode representation of SyncTask."""
|
2022-11-09 13:56:50 -05:00
|
|
|
return f'{self.id} {self.user} {self.file} {self.get_status_emoji()} {self.success_items}/{self.finished_items}/{self.total_items}'
|
2021-06-14 22:18:39 +02:00
|
|
|
|
|
|
|
def get_status_emoji(self):
|
|
|
|
return ("❌" if self.is_failed else "✔") if self.is_finished else "⚡"
|
|
|
|
|
|
|
|
def get_duration(self):
|
|
|
|
return self.ended_time - self.started_time
|
|
|
|
|
|
|
|
def get_overwritten_items(self):
|
|
|
|
if self.overwrite:
|
|
|
|
return self.overwrite_books + self.overwrite_games + self.overwrite_movies + self.overwrite_music
|
|
|
|
else:
|
|
|
|
return 0
|
|
|
|
|
|
|
|
def get_progress(self):
|
|
|
|
"""
|
|
|
|
@return: return percentage
|
|
|
|
"""
|
|
|
|
if self.is_finished:
|
|
|
|
return 100
|
|
|
|
else:
|
|
|
|
if self.total_items > 0:
|
|
|
|
return 100 * self.finished_items / self.total_items
|
|
|
|
else:
|
|
|
|
return 0
|
2021-08-29 17:52:42 +02:00
|
|
|
|
|
|
|
def get_breakpoint(self):
|
|
|
|
if not self.break_point:
|
|
|
|
return None, None
|
2021-09-01 11:41:21 +02:00
|
|
|
progress = self.break_point.split('-')
|
|
|
|
return progress[0], int(progress[1])
|
2021-08-29 17:52:42 +02:00
|
|
|
|
|
|
|
def set_breakpoint(self, sheet_name, row_index, save=False):
|
|
|
|
self.break_point = f"{sheet_name}-{row_index}"
|
|
|
|
if save:
|
|
|
|
self.save(update_fields=['break_point'])
|
|
|
|
|
|
|
|
def clear_breakpoint(self, save=False):
|
|
|
|
self.break_point = ""
|
|
|
|
if save:
|
|
|
|
self.save(update_fields=['break_point'])
|