config.cgi 4.16 KB
Newer Older
1
#!/usr/bin/perl -wT
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
# -*- Mode: perl; indent-tabs-mode: nil -*-
#
# The contents of this file are subject to the Mozilla Public
# License Version 1.1 (the "License"); you may not use this file
# except in compliance with the License. You may obtain a copy of
# the License at http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS
# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
# implied. See the License for the specific language governing
# rights and limitations under the License.
#
# The Original Code is the Bugzilla Bug Tracking System.
#
# The Initial Developer of the Original Code is Netscape Communications
# Corporation. Portions created by Netscape are
# Copyright (C) 1998 Netscape Communications Corporation. All
# Rights Reserved.
#
# Contributor(s): Terry Weissman <terry@mozilla.org>
#                 Myk Melez <myk@mozilla.org>

################################################################################
# Script Initialization
################################################################################

# Make it harder for us to do dangerous things in Perl.
use strict;

31
use lib qw(. lib);
32

33 34
use Bugzilla;
use Bugzilla::Constants;
35
use Bugzilla::Error;
36
use Bugzilla::Keyword;
37
use Bugzilla::Status;
38
use Bugzilla::Field;
39 40

my $user = Bugzilla->login(LOGIN_OPTIONAL);
41
my $cgi  = Bugzilla->cgi;
42 43 44

# If the 'requirelogin' parameter is on and the user is not
# authenticated, return empty fields.
45
if (Bugzilla->params->{'requirelogin'} && !$user->id) {
46 47 48
    display_data();
}

49 50 51
# Get data from the shadow DB as they don't change very often.
Bugzilla->switch_to_shadow_db;

52
# Pass a bunch of Bugzilla configuration to the templates.
53
my $vars = {};
54 55 56 57
$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');
58
$vars->{'keyword'}    = [map($_->name, Bugzilla::Keyword->get_all)];
59 60
$vars->{'resolution'} = get_legal_field_values('resolution');
$vars->{'status'}    = get_legal_field_values('bug_status');
61
$vars->{'custom_fields'} =
62
    [ grep {$_->is_select} Bugzilla->active_custom_fields ];
63

64
# Include a list of product objects.
65 66 67 68 69 70 71 72 73 74 75 76 77 78
if ($cgi->param('product')) {
    my @products = $cgi->param('product');
    foreach my $product_name (@products) {
        # We don't use check_product because config.cgi outputs mostly
        # 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;
}
79 80 81 82 83

# Create separate lists of open versus resolved statuses.  This should really
# be made part of the configuration.
my @open_status;
my @closed_status;
84
foreach my $status (@{$vars->{'status'}}) {
85
    is_open_state($status) ? push(@open_status, $status) 
86 87 88 89 90
                           : push(@closed_status, $status);
}
$vars->{'open_status'} = \@open_status;
$vars->{'closed_status'} = \@closed_status;

91
# Generate a list of fields that can be queried.
92 93 94 95 96 97
my @fields = @{Bugzilla::Field->match({obsolete => 0})};
# Exclude fields the user cannot query.
if (!Bugzilla->user->in_group(Bugzilla->params->{'timetrackinggroup'})) {
    @fields = grep { $_->name !~ /^(estimated_time|remaining_time|work_time|percentage_complete|deadline)$/ } @fields;
}
$vars->{'field'} = \@fields;
98

99 100 101 102 103
display_data($vars);


sub display_data {
    my $vars = shift;
104

105
    my $cgi      = Bugzilla->cgi;
106
    my $template = Bugzilla->template;
107

108 109 110 111 112 113 114 115 116 117 118 119 120
    # 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");

    # Return HTTP headers.
    print "Content-Type: $format->{'ctype'}\n\n";

    # Generate the configuration file and return it to the user.
    $template->process($format->{'template'}, $vars)
      || ThrowTemplateError($template->error());
    exit;
}