robosats/chat/tasks.py

50 lines
1.4 KiB
Python
Raw Permalink Normal View History

from celery import shared_task
2022-10-20 09:56:10 +00:00
@shared_task(name="chatrooms_cleansing")
def chatrooms_cleansing():
"""
2022-10-20 09:56:10 +00:00
Deletes chatrooms and encrypted messages of orders
that have completely finished more than 3 days ago.
"""
from datetime import timedelta
2022-10-25 18:04:12 +00:00
from django.utils import timezone
2022-10-25 18:04:12 +00:00
from api.models import Order
from chat.models import ChatRoom
2022-10-20 09:56:10 +00:00
finished_states = [
Order.Status.SUC,
Order.Status.TLD,
Order.Status.MLD,
Order.Status.CCA,
Order.Status.UCA,
]
# Orders that have expired more than 3 days ago
2022-10-20 09:56:10 +00:00
# Usually expiry takes place 1 day after a finished order. So, ~4 days
# until encrypted messages are deleted.
finished_time = timezone.now() - timedelta(days=3)
2022-10-20 09:56:10 +00:00
queryset = Order.objects.filter(
status__in=finished_states, expires_at__lt=finished_time
)
# And do not have an active trade, any past contract or any reward.
deleted_chatrooms = []
for order in queryset:
# Try an except. In case some chatroom is already missing.
try:
2022-10-20 09:56:10 +00:00
chatroom = ChatRoom.objects.get(id=order.id)
deleted_chatrooms.append(str(chatroom))
chatroom.delete()
except Exception:
pass
results = {
"num_deleted": len(deleted_chatrooms),
"deleted_chatrooms": deleted_chatrooms,
}
2022-10-20 09:56:10 +00:00
return results