]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 1230932 - Providing a condition as an ID to the webservice results in a taint...
authorDylan Hardison <dylan@mozilla.com>
Tue, 22 Dec 2015 16:53:56 +0000 (11:53 -0500)
committerDylan Hardison <dylan@mozilla.com>
Tue, 22 Dec 2015 16:54:22 +0000 (11:54 -0500)
r=dkl,a=dkl

Bugzilla/WebService/Constants.pm
Bugzilla/WebService/Util.pm
template/en/default/global/code-error.html.tmpl

index f289caef46f45e457caf72c79715fc85de09c15f..722abd124f315c21f236aa184c840457d0e754f9 100644 (file)
@@ -51,6 +51,7 @@ use constant WS_ERROR_CODE => {
     number_too_large            => 54,
     number_too_small            => 55,
     illegal_date                => 56,
+    param_integer_array_required => 58,
     # Bug errors usually occupy the 100-200 range.
     improper_bug_id_field_value => 100,
     bug_id_does_not_exist       => 101,
index c7d63b3366082cbaaf4b53bf4e4260b88c9fed54..7b2c2416d21ee7ca1b4704f8aebdad9f537dc91d 100644 (file)
@@ -9,6 +9,9 @@ package Bugzilla::WebService::Util;
 use strict;
 use base qw(Exporter);
 
+use List::MoreUtils qw(all any);
+use Bugzilla::Error;
+
 # We have to "require", not "use" this, because otherwise it tries to
 # use features of Test::More during import().
 require Test::Taint;
@@ -103,7 +106,8 @@ sub validate  {
     # sent any parameters at all, and we're getting @keys where
     # $params should be.
     return ($self, undef) if (defined $params and !ref $params);
-    
+
+    my @id_params = qw( ids comment_ids );
     # If @keys is not empty then we convert any named 
     # parameters that have scalar values to arrayrefs
     # that match.
@@ -112,6 +116,12 @@ sub validate  {
             $params->{$key} = ref $params->{$key} 
                               ? $params->{$key} 
                               : [ $params->{$key} ];
+
+            if (any { $key eq $_ } @id_params) {
+                my $ids = $params->{$key};
+                ThrowCodeError('param_integer_array_required', { param => $key })
+                  unless ref($ids) eq 'ARRAY' && all { /^[0-9]+$/ } @$ids;
+            }
         }
     }
 
index e4416326b356132e284b54310552052c307d8734..cd0e3c2aacd409784b369e7b385ad74ea7297a3c 100644 (file)
     a <code>[% param FILTER html %]</code> argument, and that
     argument was not set.
 
+  [% ELSIF error == "param_integer_array_required" %]
+    The <code>[% param FILTER html %]</code> parameter must be an array of integers.
+
   [% ELSIF error == "params_required" %]
     [% title = "Missing Parameter" %]
     The function <code>[% function FILTER html %]</code> requires