Register timeline signals in app.ready hook.

remotes/origin/enhancement/email-actions
Andrey Antukh 2014-09-03 10:36:29 +02:00
parent d9e4d30bb3
commit a5963c77e8
3 changed files with 57 additions and 6 deletions

View File

@ -0,0 +1,17 @@
# Copyright (C) 2014 Andrey Antukh <niwi@niwi.be>
# Copyright (C) 2014 Jesús Espino <jespinog@gmail.com>
# Copyright (C) 2014 David Barragán <bameda@dbarragan.com>
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
default_app_config = "taiga.timeline.apps.TimelineAppConfig"

40
taiga/timeline/apps.py Normal file
View File

@ -0,0 +1,40 @@
# Copyright (C) 2014 Andrey Antukh <niwi@niwi.be>
# Copyright (C) 2014 Jesús Espino <jespinog@gmail.com>
# Copyright (C) 2014 David Barragán <bameda@dbarragan.com>
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
from django.apps import AppConfig
from django.apps import apps
from django.db.models import signals
from . import signals as handlers
class TimelineAppConfig(AppConfig):
name = "taiga.timeline"
verbose_name = "Timeline"
def ready(self):
signals.post_save.connect(handlers.create_project_push_to_timeline,
sender=apps.get_model("projects", "Project"))
signals.post_save.connect(handlers.create_user_story_push_to_timeline,
sender=apps.get_model("userstories", "UserStory"))
signals.post_save.connect(handlers.create_issue_push_to_timeline,
sender=apps.get_model("issues", "Issue"))
signals.pre_save.connect(handlers.create_membership_push_to_timeline,
sender=apps.get_model("projects", "Membership"))
signals.post_delete.connect(handlers.delete_membership_push_to_timeline,
sender=apps.get_model("projects", "Membership"))

View File

@ -16,7 +16,6 @@
from django.db.models.loading import get_model
from django.db.models import signals
from django.dispatch import receiver
from taiga.timeline.service import push_to_timeline
@ -24,25 +23,21 @@ from taiga.timeline.service import push_to_timeline
# TODO: Add events to project watchers timeline when project watchers are implemented.
@receiver(signals.post_save, sender=get_model("projects", "Project"))
def create_project_push_to_timeline(sender, instance, created, **kwargs):
if created:
push_to_timeline(instance, instance, "create")
@receiver(signals.post_save, sender=get_model("userstories", "UserStory"))
def create_user_story_push_to_timeline(sender, instance, created, **kwargs):
if created:
push_to_timeline(instance.project, instance, "create")
@receiver(signals.post_save, sender=get_model("issues", "Issue"))
def create_issue_push_to_timeline(sender, instance, created, **kwargs):
if created:
push_to_timeline(instance.project, instance, "create")
@receiver(signals.pre_save, sender=get_model("projects", "Membership"))
def create_membership_push_to_timeline(sender, instance, **kwargs):
if not instance.pk and instance.user:
push_to_timeline(instance.project, instance, "create")
@ -60,6 +55,5 @@ def create_membership_push_to_timeline(sender, instance, **kwargs):
push_to_timeline(instance.project, instance, "role-changed", extra_data=extra_data)
@receiver(signals.post_delete, sender=get_model("projects", "Membership"))
def delete_membership_push_to_timeline(sender, instance, **kwargs):
push_to_timeline(instance.project, instance, "delete")