import logging from threading import Thread import requests from django.conf import settings from django.contrib.admin.models import LogEntry from django.contrib.sessions.models import Session from django.core.mail import send_mail from django.db import models from django.db.models.signals import post_save from django.dispatch import receiver from oidc_provider.models import Token from django.urls import NoReverseMatch from djangoldp.fields import LDPUrlField from djangoldp.models import Model from djangoldp.permissions import InboxPermissions class Notification(Model): user = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='inbox', on_delete=models.deletion.CASCADE) author = LDPUrlField() object = LDPUrlField() type = models.CharField(max_length=255) summary = models.TextField() date = models.DateTimeField(auto_now_add=True) unread = models.BooleanField(default=True) class Meta(Model.Meta): permission_classes = [InboxPermissions] ordering = ['date'] def __str__(self): return '{}'.format(self.type) class Subscription(Model): object = models.URLField() inbox = models.URLField() def __str__(self): return '{}'.format(self.object) # --- SUBSCRIPTION SYSTEM --- @receiver(post_save, dispatch_uid="callback_notif") def send_notification(sender, instance, **kwargs): if sender != Notification: threads = [] try: urlContainer = settings.BASE_URL + Model.container_id(instance) urlResource = settings.BASE_URL + Model.resource_id(instance) except NoReverseMatch: return for subscription in Subscription.objects.filter(models.Q(object=urlResource)|models.Q(object=urlContainer)): process = Thread(target=send_request, args=[subscription.inbox, urlResource]) process.start() threads.append(process) def send_request(target, object_iri): try: req = requests.post(target, json={"@context": "https://cdn.happy-dev.fr/owl/hdcontext.jsonld", "object": object_iri, "type": "update"}, headers={"Content-Type": "application/ld+json"}) except: logging.error('Djangoldp_notifications: Error with request') return True @receiver(post_save, sender=Notification) def send_email_on_notification(sender, instance, **kwargs): send_mail('Notification on staging.happy-dev.fr', instance.summary, 'from@example.com', [instance.user.email], fail_silently=False)