mirror of
https://github.com/ansible/awx.git
synced 2026-01-20 22:18:01 -03:30
* Implement concrete Notification model for notification runs * Implement NotificationTemplate and Notification serializers and views * Implement ancillary views * Implement NotificationTemplate trigger m2m fields on all job templates via a fields mixin * Link NotificationTemplates with an org * Link notifications with the activity stream * Implement Notification celery tasks * Extend Backend field parameters to identify sender and receiver as parameters needed by the message and not the backend itself * Updates to backends to better fit the django email backend model as it relates to Messages * Implement success job chain task + notifications * Implement notifications in error job chain task
72 lines
3.1 KiB
Python
72 lines
3.1 KiB
Python
# Copyright (c) 2015 Ansible, Inc.
|
|
# All Rights Reserved.
|
|
|
|
# Django
|
|
from django.db import models
|
|
from django.core.urlresolvers import reverse
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
__all__ = ['ActivityStream']
|
|
|
|
|
|
class ActivityStream(models.Model):
|
|
'''
|
|
Model used to describe activity stream (audit) events
|
|
'''
|
|
|
|
class Meta:
|
|
app_label = 'main'
|
|
|
|
OPERATION_CHOICES = [
|
|
('create', _('Entity Created')),
|
|
('update', _("Entity Updated")),
|
|
('delete', _("Entity Deleted")),
|
|
('associate', _("Entity Associated with another Entity")),
|
|
('disassociate', _("Entity was Disassociated with another Entity"))
|
|
]
|
|
|
|
actor = models.ForeignKey('auth.User', null=True, on_delete=models.SET_NULL, related_name='activity_stream')
|
|
operation = models.CharField(max_length=13, choices=OPERATION_CHOICES)
|
|
timestamp = models.DateTimeField(auto_now_add=True)
|
|
changes = models.TextField(blank=True)
|
|
|
|
object_relationship_type = models.TextField(blank=True)
|
|
object1 = models.TextField()
|
|
object2 = models.TextField()
|
|
|
|
user = models.ManyToManyField("auth.User", blank=True)
|
|
organization = models.ManyToManyField("Organization", blank=True)
|
|
inventory = models.ManyToManyField("Inventory", blank=True)
|
|
host = models.ManyToManyField("Host", blank=True)
|
|
group = models.ManyToManyField("Group", blank=True)
|
|
inventory_source = models.ManyToManyField("InventorySource", blank=True)
|
|
inventory_update = models.ManyToManyField("InventoryUpdate", blank=True)
|
|
credential = models.ManyToManyField("Credential", blank=True)
|
|
team = models.ManyToManyField("Team", blank=True)
|
|
project = models.ManyToManyField("Project", blank=True)
|
|
project_update = models.ManyToManyField("ProjectUpdate", blank=True)
|
|
permission = models.ManyToManyField("Permission", blank=True)
|
|
job_template = models.ManyToManyField("JobTemplate", blank=True)
|
|
job = models.ManyToManyField("Job", blank=True)
|
|
unified_job_template = models.ManyToManyField("UnifiedJobTemplate", blank=True, related_name='activity_stream_as_unified_job_template+')
|
|
unified_job = models.ManyToManyField("UnifiedJob", blank=True, related_name='activity_stream_as_unified_job+')
|
|
ad_hoc_command = models.ManyToManyField("AdHocCommand", blank=True)
|
|
schedule = models.ManyToManyField("Schedule", blank=True)
|
|
custom_inventory_script = models.ManyToManyField("CustomInventoryScript", blank=True)
|
|
notification_template = models.ManyToManyField("NotificationTemplate", blank=True)
|
|
notification = models.ManyToManyField("Notification", blank=True)
|
|
|
|
def get_absolute_url(self):
|
|
return reverse('api:activity_stream_detail', args=(self.pk,))
|
|
|
|
def save(self, *args, **kwargs):
|
|
# For compatibility with Django 1.4.x, attempt to handle any calls to
|
|
# save that pass update_fields.
|
|
try:
|
|
super(ActivityStream, self).save(*args, **kwargs)
|
|
except TypeError:
|
|
if 'update_fields' not in kwargs:
|
|
raise
|
|
kwargs.pop('update_fields')
|
|
super(ActivityStream, self).save(*args, **kwargs)
|