Commit 05ba0f41 authored by Max Kanat-Alexander's avatar Max Kanat-Alexander

Bug 554560: WebService Bug.fields: Send visibility_values for all select-type

fields (including built-in fields that don't support it yet), but don't send a single null in the array for fields that have no visibility values. r=dkl, a=mkanat
parent 4c622071
...@@ -93,8 +93,7 @@ sub fields { ...@@ -93,8 +93,7 @@ sub fields {
foreach my $field (@fields) { foreach my $field (@fields) {
my $visibility_field = $field->visibility_field my $visibility_field = $field->visibility_field
? $field->visibility_field->name : undef; ? $field->visibility_field->name : undef;
my $visibility_value = $field->visibility_value my $vis_value = $field->visibility_value;
? $field->visibility_value->name : undef;
my $value_field = $field->value_field my $value_field = $field->value_field
? $field->value_field->name : undef; ? $field->value_field->name : undef;
...@@ -118,7 +117,10 @@ sub fields { ...@@ -118,7 +117,10 @@ sub fields {
display_name => $self->type('string', $field->description), display_name => $self->type('string', $field->description),
is_on_bug_entry => $self->type('boolean', $field->enter_bug), is_on_bug_entry => $self->type('boolean', $field->enter_bug),
visibility_field => $self->type('string', $visibility_field), visibility_field => $self->type('string', $visibility_field),
visibility_values => [$self->type('string', $visibility_value)], visibility_values => [
defined $vis_value ? $self->type('string', $vis_value->name)
: ()
],
); );
if ($has_values) { if ($has_values) {
$field_data{value_field} = $self->type('string', $value_field); $field_data{value_field} = $self->type('string', $value_field);
...@@ -185,6 +187,7 @@ sub _legal_field_values { ...@@ -185,6 +187,7 @@ sub _legal_field_values {
is_open => $self->type('boolean', $status->is_open), is_open => $self->type('boolean', $status->is_open),
sortkey => $self->type('int', $status->sortkey), sortkey => $self->type('int', $status->sortkey),
can_change_to => \@can_change_to, can_change_to => \@can_change_to,
visibility_values => [],
}); });
} }
} }
...@@ -192,13 +195,14 @@ sub _legal_field_values { ...@@ -192,13 +195,14 @@ sub _legal_field_values {
else { else {
my @values = Bugzilla::Field::Choice->type($field)->get_all(); my @values = Bugzilla::Field::Choice->type($field)->get_all();
foreach my $value (@values) { foreach my $value (@values) {
my $visibility_value = $value->visibility_value; my $vis_val = $value->visibility_value;
my $vis_val_name = $visibility_value ? $visibility_value->name
: undef;
push(@result, { push(@result, {
name => $self->type('string', $value->name), name => $self->type('string', $value->name),
sortkey => $self->type('int' , $value->sortkey), sortkey => $self->type('int' , $value->sortkey),
visibility_values => [$self->type('string', $vis_val_name)], visibility_values => [
defined $vis_val ? $self->type('string', $vis_val->name)
: ()
],
}); });
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment