我需要在通过管理面板创建Entry
模型的新实例时发送电子邮件。所以在models.py
我有:
class Entry(models.Model):
attachments = models.ManyToManyField(to=Attachment, blank=True)
#some other fields
#...
sent = models.BooleanField(editable=False, default=False)
然后我注册了post_save处理函数:
def send_message(sender, instance, **kwargs):
if not instance.sent:
#sending an e-mail message containing details about related attachments
#...
instance.sent = True
instance.save()
post_save.connect(send_message, sender=Entry)
它有效,但正如我之前提到的,我还需要访问相关附件以在消息中包含它们的详细信息。即使实际添加了附件,不幸的instance.attachments.all()
也会在send_message
函数内返回空列表。
正如我所知,当发送post_save信号时,保存模型的相关数据尚未保存,因此我无法从该位置获取相关附件。
问题是:我能够使用信号或其他任何方式完成此操作,或者我是否必须将此电子邮件发送到外部,例如覆盖Entry
模型的管理面板更改视图?
答案 0 :(得分:2)
也许您可以使用M2M Changed Signal代替?当M2M字段改变时发送该信号。
答案 1 :(得分:1)
您应该可以通过覆盖ModelAdmin上的save_model()方法来执行此操作。您可以在那里发送电子邮件或发送自定义信号,触发您的处理程序发送电子邮件。
如果您有内联版,我相信您需要使用save_formset()代替。
答案 2 :(得分:1)
我尝试使用ModelAdmin
save_model()
方法,就像shadfc提出的那样。
无论如何,从那里也无法访问新更改的相关对象。但save_model
将填充form
作为参数,因此我使用了它。我的send_message
不再用作信号处理程序,我添加了related_data参数。
def send_message(sender, instance, related_data={}):
#sending e-mail using related_data parameter to access additional related objects
#...
在admin.py
我有:
class EntryAdmin(admin.ModelAdmin):
def save_model(self, request, obj, form, change):
obj.save()
send_message(sender=Entry, instance=obj,
related_data={'attachments': form.cleaned_data['attachments']} )