#10911 closed defect (fixed)
CommitTicketUpdater makes changes on tickets on behalf of users without checking if they have sufficient permissions
Reported by: | Owned by: | Remy Blank | |
---|---|---|---|
Priority: | normal | Milestone: | 1.0.1 |
Component: | ticket system | Version: | 1.0 |
Severity: | major | Keywords: | updater |
Cc: | Branch: | ||
Release Notes: |
CommitTicketUpdater checks for |
||
API Changes: | |||
Internal Changes: |
Description
We have a setup, where committers can view only their own tickets.
When I reference a ticket, to which I don't have permissions to even see, CommitTicketUpdater
still posts a comment on this ticket with my username and I get the notification e-mail, exposing the ticket summary and description.
I expected that if the commit_ticket_update_check_perms
option is set, I won't be able to post comments to this ticket and that I won't be able to see the ticket summary and description.
I think we should check if the user has TICKET_APPEND
permission before updating the ticket on their behalf.
Attachments (2)
Change History (10)
comment:1 by , 12 years ago
Component: | general → ticket system |
---|---|
Milestone: | → 1.0.1 |
Owner: | set to |
Status: | new → assigned |
by , 12 years ago
Attachment: | respect-ticket-permissions-in-updater.diff added |
---|
comment:2 by , 12 years ago
Hey rblank, here is the patch.
In order to have different checks in different commands, I moved the permission checks there and now _update_tickets()
just make sure all the commands return True
, instead of checking the permissions itself.
comment:4 by , 12 years ago
Perhaps out of scope for this ticket, but I'm thinking it might be useful to log, perhaps at the debug level, the specific causes of a cmd returning False
. For example: "%s doesn't have permission to add comments to Ticket #(%s)" % (changeset.author, ticket.id)
.
comment:5 by , 12 years ago
Can you please test 10911-update-perms-r11496.patch? It has two changes from your initial patch:
- The notification email must be sent outside of the transaction. You had moved it into the transaction, but this is wrong when the transaction fails.
- Commands returning
None
don't prevent the change, they must explicitly returnFalse
. This should make the change backward-compatible for people who extended the component and added commands.
comment:6 by , 12 years ago
Keywords: | updater, → updater |
---|---|
Resolution: | → fixed |
Status: | assigned → closed |
Modified patch applied in [11531]. The patch above was updating the ticket if all commands succeeded. This was wrong, and the final patch updates the ticket if at least one command succeeds. The refs
command is now gated by TICKET_APPEND
.
comment:8 by , 12 years ago
Release Notes: | modified (diff) |
---|
That makes sense, yes. Can you please provide a patch that adds this check in the loop of
_update_tickets()
?