2003-05-01 01:23:06 +04:00
|
|
|
#!/usr/bin/perl -wT
|
2003-04-30 03:14:31 +04:00
|
|
|
# -*- 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 diagnostics;
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
# Include the Bugzilla CGI and general utility library.
|
2003-05-01 01:23:06 +04:00
|
|
|
use lib qw(.);
|
2005-08-10 05:30:41 +04:00
|
|
|
require "globals.pl";
|
2003-04-30 03:14:31 +04:00
|
|
|
|
|
|
|
# Retrieve this installation's configuration.
|
|
|
|
GetVersionTable();
|
|
|
|
|
|
|
|
# Suppress "used only once" warnings.
|
|
|
|
use vars
|
|
|
|
qw(
|
|
|
|
@legal_priority
|
|
|
|
@legal_severity
|
|
|
|
@legal_platform
|
|
|
|
@legal_opsys
|
|
|
|
@legal_resolution
|
|
|
|
|
|
|
|
@legal_components
|
|
|
|
@legal_target_milestone
|
|
|
|
@legal_versions
|
|
|
|
@legal_keywords
|
|
|
|
);
|
|
|
|
|
|
|
|
# Use the global template variables defined in globals.pl
|
|
|
|
# to generate the output.
|
|
|
|
use vars qw($template $vars);
|
|
|
|
|
|
|
|
# Pass a bunch of Bugzilla configuration to the templates.
|
|
|
|
$vars->{'priority'} = \@::legal_priority;
|
|
|
|
$vars->{'severity'} = \@::legal_severity;
|
|
|
|
$vars->{'platform'} = \@::legal_platform;
|
|
|
|
$vars->{'op_sys'} = \@::legal_opsys;
|
|
|
|
$vars->{'keyword'} = \@::legal_keywords;
|
|
|
|
$vars->{'resolution'} = \@::legal_resolution;
|
|
|
|
$vars->{'status'} = \@::legal_bug_status;
|
|
|
|
|
2005-09-03 01:12:10 +04:00
|
|
|
# Include a list of product objects.
|
|
|
|
$vars->{'products'} = Bugzilla->user->get_selectable_products;
|
2003-04-30 03:14:31 +04:00
|
|
|
|
|
|
|
# Create separate lists of open versus resolved statuses. This should really
|
|
|
|
# be made part of the configuration.
|
|
|
|
my @open_status;
|
|
|
|
my @closed_status;
|
|
|
|
foreach my $status (@::legal_bug_status) {
|
|
|
|
IsOpenedState($status) ? push(@open_status, $status)
|
|
|
|
: push(@closed_status, $status);
|
|
|
|
}
|
|
|
|
$vars->{'open_status'} = \@open_status;
|
|
|
|
$vars->{'closed_status'} = \@closed_status;
|
|
|
|
|
2003-06-23 22:01:39 +04:00
|
|
|
# Generate a list of fields that can be queried.
|
2005-02-16 21:11:07 +03:00
|
|
|
$vars->{'field'} = [Bugzilla->dbh->bz_get_field_defs()];
|
2003-06-23 22:01:39 +04:00
|
|
|
|
2003-04-30 03:14:31 +04:00
|
|
|
# Determine how the user would like to receive the output;
|
|
|
|
# default is JavaScript.
|
2004-03-27 00:00:11 +03:00
|
|
|
my $cgi = Bugzilla->cgi;
|
2005-08-25 18:02:41 +04:00
|
|
|
my $format = $template->get_format("config", scalar($cgi->param('format')),
|
|
|
|
scalar($cgi->param('ctype')) || "js");
|
2003-04-30 03:14:31 +04:00
|
|
|
|
|
|
|
# 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());
|