Opened 7 years ago
Last modified 4 years ago
#13029 new defect
Attachment notifications despite Never notify: I update a ticket
Reported by: | anonymous | Owned by: | |
---|---|---|---|
Priority: | normal | Milestone: | next-dev-1.7.x |
Component: | attachment | Version: | 1.2.2 |
Severity: | normal | Keywords: | |
Cc: | Branch: | ||
Release Notes: | |||
API Changes: | |||
Internal Changes: |
Description (last modified by )
I have configured:
Subscription rules: Never notify: I update a ticket
And this works well most of the time, but I still get a notification when I attach a file to a ticket.
Attachments (0)
Change History (16)
comment:1 by , 7 years ago
follow-ups: 7 14 comment:2 by , 7 years ago
Description: | modified (diff) |
---|---|
Type: | enhancement → defect |
Version: | → 1.2.2 |
And this works well most of the time, but I still get a notification when I attach a file to a ticket.
I tested the case on Trac 1.2.2 but works for me.
browser:trunk/trac/ticket/notification.py@16368:683#L658 is this correct when the attachment is not added by the ticket reporter?
You're right. We should use attachment.author
as author
argument.
-
trac/ticket/notification.py
diff --git a/trac/ticket/notification.py b/trac/ticket/notification.py index 92957d016..e34cda923 100644
a b class TicketAttachmentNotifier(Component): 896 896 897 897 def attachment_added(self, attachment): 898 898 self._notify_attachment(attachment, 'attachment added', 899 attachment.date )899 attachment.date, attachment.author) 900 900 901 901 def attachment_deleted(self, attachment): 902 self._notify_attachment(attachment, 'attachment deleted', None )902 self._notify_attachment(attachment, 'attachment deleted', None, None) 903 903 904 904 def attachment_reparented(self, attachment, old_parent_realm, 905 905 old_parent_id): … … class TicketAttachmentNotifier(Component): 907 907 908 908 # Internal methods 909 909 910 def _notify_attachment(self, attachment, category, time ):910 def _notify_attachment(self, attachment, category, time, author): 911 911 resource = attachment.resource.parent 912 912 if resource.realm != 'ticket': 913 913 return 914 914 ticket = Ticket(self.env, resource.id) 915 event = TicketChangeEvent(category, ticket, time, ticket['reporter'],915 event = TicketChangeEvent(category, ticket, time, author, 916 916 attachment=attachment) 917 917 try: 918 918 NotificationSystem(self.env).notify(event)
However, author is not available when deleting attachment. I consider we should implement the notification in AttachmentModule.process_request
to pass req.authname
to the author.
comment:3 by , 7 years ago
Milestone: | → 1.2.4 |
---|
comment:5 by , 6 years ago
Milestone: | 1.2.4 → 1.2.5 |
---|
comment:6 by , 5 years ago
Owner: | set to |
---|---|
Status: | new → assigned |
follow-ups: 8 9 comment:7 by , 5 years ago
Replying to Jun Omae:
However, author is not available when deleting attachment. I consider we should implement the notification in
AttachmentModule.process_request
to passreq.authname
to the author.
What if we added author
parameter to Attachment.delete
and IAttachmentChangeListener.attachment_deleted
?
comment:8 by , 5 years ago
Replying to Ryan J Ollos:
What if we added
author
parameter toAttachment.delete
andIAttachmentChangeListener.attachment_deleted
?
Proposed changes: log:rjollos.git:t13029_attachment_notifications. I will add test coverage.
TODO Make IAttachmentChangeListener
API changes in #12787.
follow-ups: 10 12 comment:9 by , 5 years ago
Replying to Ryan J Ollos:
Replying to Jun Omae:
However, author is not available when deleting attachment. I consider we should implement the notification in
AttachmentModule.process_request
to passreq.authname
to the author.What if we added
author
parameter toAttachment.delete
andIAttachmentChangeListener.attachment_deleted
?
If we add author
parameter to Attachment.delete()
, I think we should add to Ticket.delete()
and Wiki.delete()
also. If we don't change Ticket.delete()
, I don't think we should change Attachment.delete()
.
Methods without author parameter:
- Wiki:
Wiki.delete(self, version=None)
Wiki.rename(self, new_name)
Wiki.edit_comment(self, new_comment)
- Ticket:
Ticket.insert(self, when=None)
ticket['reporter']
can be used
Ticket.delete(self)
Ticket.delete_change(self, cnum=None, cdate=None, when=None)
Ticket.modify_comment(self, cdate, author, comment, when=None)
- Milestone:
Milestone.insert(self)
Milestone.delete(self)
- Attachment:
Attachment.insert(self, filename, fileobj, size, t=None)
attachment.author
can be used
Attachment.delete(self)
Attachment.move(self, new_realm=None, new_id=None, new_filename=None)
Attachment.reparent(self, new_realm, new_id)
Attachment.delete_all(cls, env, parent_realm, parent_id)
Attachment.reparent_all(cls, env, parent_realm, parent_id, new_realm, new_id)
comment:10 by , 5 years ago
Replying to Jun Omae:
If we add
author
parameter toAttachment.delete()
, I think we should add toTicket.delete()
…
The proposed changes already include addition of author
parameter to Ticket.delete()
.
comment:11 by , 5 years ago
Milestone: | 1.2.5 → 1.2.6 |
---|
comment:12 by , 5 years ago
comment:13 by , 5 years ago
Milestone: | 1.2.6 → 1.4.2 |
---|
comment:14 by , 5 years ago
Milestone: | 1.4.2 → next-dev-1.5.x |
---|
Replying to Jun Omae:
However, author is not available when deleting attachment. I consider we should implement the notification in
AttachmentModule.process_request
to passreq.authname
to the author.
It could be fine as a short-term solution, but I don't think we should be importing from the ticket
package in the attachment
module. I suppose we could implement in post_process_request
.
This is the same problem discussed in #12414 and #13282:
I think it's been discussed before,
ITicketChangeListener
might be more useful if the request was passed as an argument. One way would be to move the call toITicketChangeListener
out of the model object.
Moving the issue forward until a better solution can be arrived at, which hopefully addresses all of the issues discussed in these tickets.
comment:15 by , 5 years ago
Owner: | removed |
---|---|
Status: | assigned → new |
browser:trunk/trac/ticket/notification.py@16368:683#L658 is this correct when the attachment is not added by the ticket reporter?