]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 927497 - "Add me to CC list" feature of bug creation screen gives token error
authorDave Lawrence <dlawrence@mozilla.com>
Tue, 29 Oct 2013 19:52:49 +0000 (15:52 -0400)
committerDave Lawrence <dlawrence@mozilla.com>
Tue, 29 Oct 2013 19:52:49 +0000 (15:52 -0400)
r=LpSolit,a=glob

Bugzilla/WebService/Bug.pm

index b24b53dfb4d5bd1aca69e2f6f4c896d9686adf2a..30d07d1f4af338e8fe2849e0d0d07977e49d63c7 100644 (file)
@@ -341,8 +341,7 @@ sub get {
     my $ids = $params->{ids};
     defined $ids || ThrowCodeError('param_required', { param => 'ids' });
 
-    my @bugs;
-    my @faults;
+    my (@bugs, @faults, @hashes);
 
     # Cache permissions for bugs. This highly reduces the number of calls to the DB.
     # visible_bugs() is only able to handle bug IDs, so we have to skip aliases.
@@ -366,7 +365,8 @@ sub get {
         else {
             $bug = Bugzilla::Bug->check($bug_id);
         }
-        push(@bugs, $self->_bug_to_hash($bug, $params));
+        push(@bugs, $bug);
+        push(@hashes, $self->_bug_to_hash($bug, $params));
     }
 
     # Set the ETag before inserting the update tokens
@@ -374,14 +374,9 @@ sub get {
     # the data has not changed.
     $self->bz_etag(\@bugs);
 
-    if (Bugzilla->user->id) {
-        foreach my $bug (@bugs) {
-            my $token = issue_hash_token([$bug->{'id'}, $bug->{'last_change_time'}]);
-            $bug->{'update_token'} = $self->type('string', $token);
-        }
-    }
+    $self->_add_update_tokens($params, \@bugs, \@hashes);
 
-    return { bugs => \@bugs, faults => \@faults };
+    return { bugs => \@hashes, faults => \@faults };
 }
 
 # this is a function that gets bug activity for list of bug ids 
@@ -566,6 +561,7 @@ sub possible_duplicates {
         { summary => $params->{summary}, products => \@products,
           limit   => $params->{limit} });
     my @hashes = map { $self->_bug_to_hash($_, $params) } @$possible_dupes;
+    $self->_add_update_tokens($params, $possible_dupes, \@hashes);
     return { bugs => \@hashes };
 }
 
@@ -1219,6 +1215,18 @@ sub _flag_to_hash {
     return $item;
 }
 
+sub _add_update_tokens {
+    my ($self, $params, $bugs, $hashes) = @_;
+
+    return if !Bugzilla->user->id;
+    return if !filter_wants($params, 'update_token');
+
+    for(my $i = 0; $i < @$bugs; $i++) {
+        my $token = issue_hash_token([$bugs->[$i]->id, $bugs->[$i]->delta_ts]);
+        $hashes->[$i]->{'update_token'} = $self->type('string', $token);
+    }
+}
+
 1;
 
 __END__