From 92224d6dc9a07be059c517d90d23329127e985f8 Mon Sep 17 00:00:00 2001 From: Jonathan Weth <git@jonathanweth.de> Date: Sun, 5 Jun 2022 16:13:11 +0200 Subject: [PATCH] Sync rooms in separate tasks --- aleksis/apps/matrix/model_extensions.py | 1 - aleksis/apps/matrix/signals.py | 3 --- aleksis/apps/matrix/tasks.py | 4 +++- 3 files changed, 3 insertions(+), 5 deletions(-) diff --git a/aleksis/apps/matrix/model_extensions.py b/aleksis/apps/matrix/model_extensions.py index 4e0472b..205ee40 100644 --- a/aleksis/apps/matrix/model_extensions.py +++ b/aleksis/apps/matrix/model_extensions.py @@ -22,7 +22,6 @@ def provision_in_matrix(self, sync: bool = False) -> Union[MatrixRoom, AsyncResu def _provision_in_matrix(self) -> MatrixRoom: """Create and sync a room for this group in Matrix.""" room = MatrixRoom.from_group(self) - room.sync() return room diff --git a/aleksis/apps/matrix/signals.py b/aleksis/apps/matrix/signals.py index 10db2f5..0b67a1f 100644 --- a/aleksis/apps/matrix/signals.py +++ b/aleksis/apps/matrix/signals.py @@ -8,9 +8,6 @@ from .tasks import sync_room def post_save_matrix_signal(sender, instance, created, **kwargs): """Sync Matrix room after changing a group/Matrix room/Matrix profile.""" - if created: - return - rooms = [] if isinstance(instance, Group): rooms = MatrixRoom.objects.filter(group=instance) diff --git a/aleksis/apps/matrix/tasks.py b/aleksis/apps/matrix/tasks.py index f61f53b..8574b3a 100644 --- a/aleksis/apps/matrix/tasks.py +++ b/aleksis/apps/matrix/tasks.py @@ -1,6 +1,8 @@ from datetime import timedelta from typing import Sequence +from celery.task.sets import TaskSet + from aleksis.apps.matrix.models import MatrixRoom from aleksis.core.celery import app from aleksis.core.models import Group @@ -33,4 +35,4 @@ def sync_rooms(): """Synchronise all Matrix rooms.""" rooms = MatrixRoom.objects.all() for room in rooms: - room.sync() + sync_room.delay(room.pk) -- GitLab