diff options
Diffstat (limited to 'extensions/Push/lib/Connector')
-rw-r--r-- | extensions/Push/lib/Connector/Phabricator.pm | 30 |
1 files changed, 22 insertions, 8 deletions
diff --git a/extensions/Push/lib/Connector/Phabricator.pm b/extensions/Push/lib/Connector/Phabricator.pm index 8a307ea72..b9917d7c1 100644 --- a/extensions/Push/lib/Connector/Phabricator.pm +++ b/extensions/Push/lib/Connector/Phabricator.pm @@ -23,7 +23,7 @@ use Bugzilla::Extension::PhabBugz::Util qw( add_comment_to_revision create_private_revision_policy edit_revision_policy get_attachment_revisions get_bug_role_phids get_revisions_by_ids intersect is_attachment_phab_revision - make_revision_public make_revision_private); + make_revision_public make_revision_private set_revision_subscribers); use Bugzilla::Extension::Push::Constants; use Bugzilla::Extension::Push::Util qw(is_public); @@ -44,9 +44,10 @@ sub should_send { return 0 unless Bugzilla->params->{phabricator_enabled}; + # We are only interested currently in bug group, assignee, qa-contact, or cc changes. return 0 unless $message->routing_key =~ - /^(?:attachment|bug)\.modify:.*\bbug_group\b/; + /^(?:attachment|bug)\.modify:.*\b(bug_group|assigned_to|qa_contact|cc)\b/; my $bug = $self->_get_bug_by_data( $message->payload_decoded ) || return 0; @@ -59,6 +60,7 @@ sub send { my $logger = Bugzilla->push_ext->logger; my $data = $message->payload_decoded; + my $bug = $self->_get_bug_by_data($data) || return PUSH_RESULT_OK; my $is_public = is_public($bug); @@ -73,11 +75,12 @@ sub send { my @set_groups = intersect( $bug_group_names, $sync_group_names ); + my @revisions = get_attachment_revisions($bug); + if ( !$is_public && !@set_groups ) { my $phab_error_message = 'Revision is being made private due to unknown Bugzilla groups.'; - my @revisions = get_attachment_revisions($bug); foreach my $revision (@revisions) { Bugzilla->audit(sprintf( 'Making revision %s for bug %s private due to unkown Bugzilla groups: %s', @@ -109,18 +112,20 @@ sub send { return PUSH_RESULT_OK; } - my $policy_phid; + my $group_change = + ($message->routing_key =~ /^(?:attachment|bug)\.modify:.*\bbug_group\b/) + ? 1 + : 0; + my $subscribers; if ( !$is_public ) { - $policy_phid = create_private_revision_policy( $bug, \@set_groups ); $subscribers = get_bug_role_phids($bug); } - my @revisions = get_attachment_revisions($bug); foreach my $revision (@revisions) { my $revision_phid = $revision->{phid}; - if ($is_public) { + if ( $is_public && $group_change ) { Bugzilla->audit(sprintf( 'Making revision %s public for bug %s', $revision->{id}, @@ -128,14 +133,23 @@ sub send { )); make_revision_public($revision_phid); } - else { + elsif ( !$is_public && $group_change ) { Bugzilla->audit(sprintf( 'Giving revision %s a custom policy for bug %s', $revision->{id}, $bug->id )); + my $policy_phid = create_private_revision_policy( $bug, \@set_groups ); edit_revision_policy( $revision_phid, $policy_phid, $subscribers ); } + elsif ( !$is_public && !$group_change ) { + Bugzilla->audit(sprintf( + 'Updating subscribers for %s for bug %s', + $revision->{id}, + $bug->id + )); + set_revision_subscribers( $revision_phid, $subscribers ); + } } return PUSH_RESULT_OK; |