config.cgi 4.81 KB
Newer Older
1
#!/usr/bin/perl -wT
2 3 4
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
5
#
6 7
# This Source Code Form is "Incompatible With Secondary Licenses", as
# defined by the Mozilla Public License, v. 2.0.
8

9
use 5.10.1;
10
use strict;
11
use lib qw(. lib);
12

13 14
use Bugzilla;
use Bugzilla::Constants;
15
use Bugzilla::Error;
16
use Bugzilla::Keyword;
17
use Bugzilla::Product;
18
use Bugzilla::Status;
19
use Bugzilla::Field;
20

21
use Digest::MD5 qw(md5_base64);
22 23

my $user = Bugzilla->login(LOGIN_OPTIONAL);
24
my $cgi  = Bugzilla->cgi;
25

26 27 28
# Get data from the shadow DB as they don't change very often.
Bugzilla->switch_to_shadow_db;

29 30
# If the 'requirelogin' parameter is on and the user is not
# authenticated, return empty fields.
31
if (Bugzilla->params->{'requirelogin'} && !$user->id) {
32
    display_data();
33
    exit;
34 35
}

36
# Pass a bunch of Bugzilla configuration to the templates.
37
my $vars = {};
38 39 40 41
$vars->{'priority'}  = get_legal_field_values('priority');
$vars->{'severity'}  = get_legal_field_values('bug_severity');
$vars->{'platform'}  = get_legal_field_values('rep_platform');
$vars->{'op_sys'}    = get_legal_field_values('op_sys');
42
$vars->{'keywords'}  = [Bugzilla::Keyword->get_all];
43 44
$vars->{'resolution'} = get_legal_field_values('resolution');
$vars->{'status'}    = get_legal_field_values('bug_status');
45
$vars->{'custom_fields'} =
46
    [ grep {$_->is_select} Bugzilla->active_custom_fields ];
47

48
# Include a list of product objects.
49 50 51
if ($cgi->param('product')) {
    my @products = $cgi->param('product');
    foreach my $product_name (@products) {
52
        # We don't use check() because config.cgi outputs mostly
53 54 55 56 57 58 59 60 61 62
        # in XML and JS and we don't want to display an HTML error
        # instead of that.
        my $product = new Bugzilla::Product({ name => $product_name });
        if ($product && $user->can_see_product($product->name)) {
            push (@{$vars->{'products'}}, $product);
        }
    }
} else {
    $vars->{'products'} = $user->get_selectable_products;
}
63

64 65
# We set the 2nd argument to 1 to also preload flag types.
Bugzilla::Product::preload($vars->{'products'}, 1);
66

67 68 69 70 71 72 73 74 75 76 77 78
if (Bugzilla->params->{'useclassification'}) {
    my $class = {};
    # Get all classifications with at least one selectable product.
    foreach my $product (@{$vars->{'products'}}) {
        $class->{$product->classification_id} ||= $product->classification;
    }
    my @classifications = sort {$a->sortkey <=> $b->sortkey
        || lc($a->name) cmp lc($b->name)} (values %$class);
    $vars->{'class_names'} = $class;
    $vars->{'classifications'} = \@classifications;
}

79 80 81 82 83 84 85 86 87
# Allow consumers to specify whether or not they want flag data.
if (defined $cgi->param('flags')) {
    $vars->{'show_flags'} = $cgi->param('flags');
}
else {
    # We default to sending flag data.
    $vars->{'show_flags'} = 1;
}

88 89 90 91
# Create separate lists of open versus resolved statuses.  This should really
# be made part of the configuration.
my @open_status;
my @closed_status;
92
foreach my $status (@{$vars->{'status'}}) {
93
    is_open_state($status) ? push(@open_status, $status) 
94 95 96 97 98
                           : push(@closed_status, $status);
}
$vars->{'open_status'} = \@open_status;
$vars->{'closed_status'} = \@closed_status;

99
# Generate a list of fields that can be queried.
100 101
my @fields = @{Bugzilla::Field->match({obsolete => 0})};
# Exclude fields the user cannot query.
102
if (!$user->is_timetracker) {
103 104
    @fields = grep { $_->name !~ /^(estimated_time|remaining_time|work_time|percentage_complete|deadline)$/ } @fields;
}
105 106 107 108 109 110 111 112 113 114 115 116

my %FIELD_PARAMS = (
    classification    => 'useclassification',
    target_milestone  => 'usetargetmilestone',
    qa_contact        => 'useqacontact',
    status_whiteboard => 'usestatuswhiteboard',
    see_also          => 'use_see_also',
);
foreach my $field (@fields) {
    my $param = $FIELD_PARAMS{$field->name};
    $field->{is_active} =  Bugzilla->params->{$param} if $param;
}
117
$vars->{'field'} = \@fields;
118

119 120 121 122 123
display_data($vars);


sub display_data {
    my $vars = shift;
124

125
    my $cgi      = Bugzilla->cgi;
126
    my $template = Bugzilla->template;
127

128 129 130 131 132
    # Determine how the user would like to receive the output; 
    # default is JavaScript.
    my $format = $template->get_format("config", scalar($cgi->param('format')),
                                       scalar($cgi->param('ctype')) || "js");

133 134 135
    # Generate the configuration data.
    my $output;
    $template->process($format->{'template'}, $vars, \$output)
136
      || ThrowTemplateError($template->error());
137 138 139 140 141 142

    # Wide characters cause md5_base64() to die.
    my $digest_data = $output;
    utf8::encode($digest_data) if utf8::is_utf8($digest_data);
    my $digest = md5_base64($digest_data);

143 144 145 146 147
    $cgi->check_etag($digest);

    print $cgi->header (-ETag => $digest,
                        -type => $format->{'ctype'});
    print $output;
148
}