代码拉取完成,页面将自动刷新
#!/usr/bin/env perl
# 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/.
#
# This Source Code Form is "Incompatible With Secondary Licenses", as
# defined by the Mozilla Public License, v. 2.0.
##############################################################################
#
# enter_bug.cgi
# -------------
# Displays bug entry form. Bug fields are specified through popup menus,
# drop-down lists, or text fields. Default for these values can be
# passed in as parameters to the cgi.
#
##############################################################################
use 5.10.1;
use strict;
use warnings;
use lib qw(. lib local/lib/perl5);
use Bugzilla;
use Bugzilla::Constants;
use Bugzilla::Util;
use Bugzilla::Error;
use Bugzilla::Bug;
use Bugzilla::User;
use Bugzilla::Hook;
use Bugzilla::Product;
use Bugzilla::Classification;
use Bugzilla::Keyword;
use Bugzilla::Token;
use Bugzilla::Field;
use Bugzilla::Status;
use Bugzilla::UserAgent;
my $user = Bugzilla->login(LOGIN_REQUIRED);
my $cloned_bug;
my $cloned_bug_id;
my $cgi = Bugzilla->cgi;
my $dbh = Bugzilla->dbh;
my $template = Bugzilla->template;
my $vars = {};
# BMO add a hook for the guided extension
Bugzilla::Hook::process('enter_bug_start', {vars => $vars});
# All pages point to the same part of the documentation.
$vars->{'doc_section'} = 'using/filing.html';
if (!$vars->{'disable_guided'}) {
# Purpose: force guided format for newbies
$cgi->param(-name => 'format', -value => 'guided')
if !$cgi->param('format') && !$user->in_group('canconfirm');
$cgi->delete('format')
if ($cgi->param('format') && ($cgi->param('format') eq "__default__"));
}
my $product_name = trim($cgi->param('product') || '');
# Will contain the product object the bug is created in.
my $product;
if ($product_name eq '') {
# If the user cannot enter bugs in any product, stop here.
my @enterable_products = @{$user->get_enterable_products};
ThrowUserError('no_products') unless scalar(@enterable_products);
# MOZILLA CUSTOMIZATION
# skip the classification selection page
my $classification;
if (Bugzilla->params->{'useclassification'}) {
$classification = scalar($cgi->param('classification')) || '__all';
}
else {
$classification = '__all';
}
# Unless a real classification name is given, we sort products
# by classification.
my @classifications;
unless ($classification && $classification ne '__all') {
if (Bugzilla->params->{'useclassification'}) {
my $class;
# Get all classifications with at least one enterable product.
foreach my $product (@enterable_products) {
$class->{$product->classification_id}->{'object'}
||= new Bugzilla::Classification($product->classification_id);
# Nice way to group products per classification, without querying
# the DB again.
push(@{$class->{$product->classification_id}->{'products'}}, $product);
}
@classifications = sort {
$a->{'object'}->sortkey <=> $b->{'object'}->sortkey
|| lc($a->{'object'}->name) cmp lc($b->{'object'}->name)
} (values %$class);
}
else {
@classifications = ({object => undef, products => \@enterable_products});
}
}
unless ($classification) {
# We know there is at least one classification available,
# else we would have stopped earlier.
if (scalar(@classifications) > 1) {
# We only need classification objects.
$vars->{'classifications'} = [map { $_->{'object'} } @classifications];
$vars->{'target'} = "enter_bug.cgi";
$vars->{'format'} = $cgi->param('format');
$vars->{'cloned_bug_id'} = $cgi->param('cloned_bug_id');
print $cgi->header();
$template->process("global/choose-classification.html.tmpl", $vars)
|| ThrowTemplateError($template->error());
exit;
}
# If we come here, then there is only one classification available.
$classification = $classifications[0]->{'object'}->name;
}
# Keep only enterable products which are in the specified classification.
if ($classification ne "__all") {
my $class = new Bugzilla::Classification({'name' => $classification});
# If the classification doesn't exist, then there is no product in it.
if ($class) {
@enterable_products
= grep { $_->classification_id == $class->id } @enterable_products;
@classifications = ({object => $class, products => \@enterable_products});
}
else {
@enterable_products = ();
}
}
if (scalar(@enterable_products) == 0) {
ThrowUserError('no_products');
}
elsif (scalar(@enterable_products) > 1) {
$vars->{'classifications'} = \@classifications;
$vars->{'target'} = "enter_bug.cgi";
$vars->{'format'} = $cgi->param('format');
$vars->{'cloned_bug_id'} = $cgi->param('cloned_bug_id');
print $cgi->header();
$template->process("global/choose-product.html.tmpl", $vars)
|| ThrowTemplateError($template->error());
exit;
}
else {
# Only one product exists.
$product = $enterable_products[0];
}
}
# We need to check and make sure that the user has permission
# to enter a bug against this product.
$product = $user->can_enter_product($product || $product_name, THROW_ERROR);
##############################################################################
# Useful Subroutines
##############################################################################
sub formvalue {
my ($name, $default) = (@_);
return Bugzilla->cgi->param($name) || $default || "";
}
##############################################################################
# End of subroutines
##############################################################################
my $has_editbugs = $user->in_group('editbugs', $product->id);
my $has_canconfirm = $user->in_group('canconfirm', $product->id);
# If a user is trying to clone a bug
# Check that the user has authorization to view the parent bug
# Create an instance of Bug that holds the info from the parent
$cloned_bug_id = $cgi->param('cloned_bug_id');
if ($cloned_bug_id) {
$cloned_bug = Bugzilla::Bug->check($cloned_bug_id);
$cloned_bug_id = $cloned_bug->id;
}
# If cloned bug has comments restricted then do not
# allow cloning if user is not in editbugs
if ( $cloned_bug
&& $cloned_bug->restrict_comments
&& !$user->in_group('editbugs'))
{
ThrowUserError('clone_bug_not_allowed');
}
# If there is only one active component, choose it
my @active = grep { $_->is_active } @{$product->components};
if (scalar(@active) == 1) {
$cgi->param('component', $active[0]->name);
}
# If there is only one active version, choose it
@active = grep { $_->is_active } @{$product->versions};
if (scalar(@active) == 1) {
$cgi->param('version', $active[0]->name);
}
my %default;
$vars->{'product'} = $product;
$vars->{'bug_type'} = get_legal_field_values('bug_type');
$vars->{'priority'} = get_legal_field_values('priority');
$vars->{'bug_severity'} = get_legal_field_values('bug_severity');
$vars->{'rep_platform'} = get_legal_field_values('rep_platform');
$vars->{'op_sys'} = get_legal_field_values('op_sys');
$vars->{'assigned_to'} = formvalue('assigned_to');
$vars->{'assigned_to_disabled'} = !$has_editbugs;
$vars->{'cc_disabled'} = 0;
$vars->{'qa_contact'} = formvalue('qa_contact');
$vars->{'qa_contact_disabled'} = !$has_editbugs;
$vars->{'needinfo_from'} = formvalue('needinfo_from');
$vars->{'cloned_bug_id'} = $cloned_bug_id;
$vars->{'token'} = issue_session_token('create_bug');
my @enter_bug_fields = grep { $_->enter_bug } Bugzilla->active_custom_fields;
foreach my $field (@enter_bug_fields) {
my $cf_name = $field->name;
my $cf_value = $cgi->param($cf_name);
if (defined $cf_value) {
if ($field->type == FIELD_TYPE_MULTI_SELECT) {
$cf_value = [$cgi->param($cf_name)];
}
$default{$cf_name} = $vars->{$cf_name} = $cf_value;
}
}
# This allows the Field visibility and value controls to work with the
# Classification and Product fields as a parent.
$default{'classification'} = $product->classification->name;
$default{'product'} = $product->name;
# Bug priority and severity may require special permissions
# to set from the new bug form. Also we do not allow cloning of
# the values from another bug so the new bug can be triaged properly.
my $fake_bug = Bugzilla::Extension::BMO::FakeBug->new;
$default{'priority'}
= $fake_bug->check_can_change_field('priority', 0, 1)->{allowed}
? formvalue('priority', Bugzilla->params->{'defaultpriority'})
: Bugzilla->params->{'defaultpriority'};
$default{'bug_severity'}
= $fake_bug->check_can_change_field('bug_severity', 0, 1)->{allowed}
? formvalue('bug_severity', Bugzilla->params->{'defaultseverity'})
: Bugzilla->params->{'defaultseverity'};
if ($cloned_bug_id) {
# BMO: allow form value component to override the cloned bug component
$default{'component_'} = formvalue('component') || $cloned_bug->component;
$default{'bug_type'} = $cloned_bug->bug_type;
$default{'rep_platform'} = $cloned_bug->rep_platform;
$default{'op_sys'} = $cloned_bug->op_sys;
$vars->{'short_desc'} = $cloned_bug->short_desc;
$vars->{'bug_file_loc'} = $cloned_bug->bug_file_loc;
$vars->{'keywords'} = $cloned_bug->keywords;
$vars->{'dependson'} = join(", ", $cloned_bug_id, @{$cloned_bug->dependson});
$vars->{'blocked'} = join(", ", @{$cloned_bug->blocked});
$vars->{'regressed_by'} = join(", ", @{$cloned_bug->regressed_by});
$vars->{'deadline'} = $cloned_bug->deadline;
$vars->{'estimated_time'} = $cloned_bug->estimated_time;
$vars->{'status_whiteboard'} = $cloned_bug->status_whiteboard;
if (defined $cloned_bug->cc) {
$vars->{'cc'} = join(", ", @{$cloned_bug->cc});
}
else {
$vars->{'cc'} = formvalue('cc');
}
if ($cloned_bug->reporter->id != $user->id) {
$vars->{'cc'} = join(", ", $cloned_bug->reporter->login, $vars->{'cc'});
}
foreach my $field (@enter_bug_fields) {
my $field_name = $field->name;
$vars->{$field_name} = $cloned_bug->$field_name;
}
# We need to ensure that we respect the 'insider' status of
# the first comment, if it has one. Either way, make a note
# that this bug was cloned from another bug.
my $bug_desc = $cloned_bug->comments({order => 'oldest_to_newest'})->[0];
my $isprivate = $bug_desc->is_private;
$vars->{'comment'} = "";
$vars->{'comment_is_private'} = 0;
if (!$isprivate || Bugzilla->user->is_insider) {
# We use "body" to avoid any format_comment text, which would be
# pointless to clone.
$vars->{'comment'} = $bug_desc->body;
$vars->{'comment_is_private'} = $isprivate;
}
# BMO Bug 1019747
$vars->{'cloned_bug'} = $cloned_bug;
# BMO Allow mentors to be cloned as well
$vars->{'bug_mentors'} = join(', ', map { $_->login } @{$cloned_bug->mentors});
# Cloned bugs should never inherit the 'triaged' keyword
$vars->{'keywords'} = join(', ', grep { $_ ne 'triaged' } split(/,\s*/, $vars->{keywords}));
} # end of cloned bug entry form
else {
$default{'component_'} = formvalue('component');
$default{'bug_type'}
= defined $cgi->param('regressed_by')
? 'defect'
: formvalue('bug_type',
($product->default_bug_type || Bugzilla->params->{'default_bug_type'}));
# BMO - use per-product default hw/os
$default{'rep_platform'}
= formvalue('rep_platform', $product->default_platform // detect_platform());
$default{'op_sys'}
= formvalue('op_sys', $product->default_op_sys // detect_op_sys());
$vars->{'rep_platform'} = detect_platform();
$vars->{'rep_op_sys'} = detect_op_sys();
$vars->{'alias'} = formvalue('alias');
$vars->{'short_desc'} = formvalue('short_desc');
$vars->{'bug_file_loc'} = formvalue('bug_file_loc');
$vars->{'keywords'} = formvalue('keywords');
$vars->{'dependson'} = formvalue('dependson');
$vars->{'blocked'} = formvalue('blocked');
$vars->{'regressed_by'} = formvalue('regressed_by');
$vars->{'deadline'} = formvalue('deadline');
$vars->{'estimated_time'} = formvalue('estimated_time');
$vars->{'status_whiteboard'} = formvalue('status_whiteboard');
$vars->{'bug_ignored'} = formvalue('bug_ignored');
$vars->{'see_also'} = formvalue('see_also');
$vars->{'cc'} = join(', ', $cgi->param('cc'));
$vars->{'comment'} = formvalue('comment');
$vars->{'comment_is_private'} = formvalue('comment_is_private');
# BMO Add support for mentors
$vars->{'bug_mentors'} = formvalue('bug_mentors');
} # end of normal/bookmarked entry form
# IF this is a cloned bug,
# AND the clone's product is the same as the parent's
# THEN use the version from the parent bug
# ELSE IF a version is supplied in the URL
# THEN use it
# ELSE
# The default version is the last one in the list (which, it is
# hoped, will be the most recent one).
#
# Eventually maybe each product should have a "current version"
# parameter.
$vars->{'version'} = $product->versions;
if (($cloned_bug_id) && ($product->name eq $cloned_bug->product)) {
$default{'version'} = $cloned_bug->version;
}
elsif (formvalue('version')) {
$default{'version'} = formvalue('version');
}
else {
$default{'version'} = $product->default_version;
}
# Get list of milestones.
if (Bugzilla->params->{'usetargetmilestone'}) {
$vars->{'target_milestone'} = $product->milestones;
if (formvalue('target_milestone')) {
$default{'target_milestone'} = formvalue('target_milestone');
}
else {
$default{'target_milestone'} = $product->default_milestone;
}
}
# Construct the list of allowable statuses.
my @statuses = @{Bugzilla::Status->can_change_to()};
# Exclude closed states from the UI, even if the workflow allows them.
# The back-end code will still accept them, though.
@statuses = grep { $_->is_open } @statuses;
# UNCONFIRMED is illegal if allows_unconfirmed is false.
if (!$product->allows_unconfirmed) {
@statuses = grep { $_->name ne 'UNCONFIRMED' } @statuses;
}
scalar(@statuses) || ThrowUserError('no_initial_bug_status');
# If the user has no privs...
unless ($has_editbugs || $has_canconfirm) {
# ... use UNCONFIRMED if available, else use the first status of the list.
my ($unconfirmed) = grep { $_->name eq 'UNCONFIRMED' } @statuses;
# Because of an apparent Perl bug, "$unconfirmed || $statuses[0]" doesn't
# work, so we're using an "?:" operator. See bug 603314 for details.
@statuses = ($unconfirmed ? $unconfirmed : $statuses[0]);
}
$vars->{'bug_status'} = \@statuses;
# Get the default from a template value if it is legitimate.
# Otherwise, and only if the user has privs, set the default
# to the first confirmed bug status on the list, if available.
my $picked_status = formvalue('bug_status');
if ($picked_status and grep($_->name eq $picked_status, @statuses)) {
$default{'bug_status'} = formvalue('bug_status');
}
elsif (scalar @statuses == 1) {
$default{'bug_status'} = $statuses[0]->name;
}
else {
$default{'bug_status'}
= ($statuses[0]->name ne 'UNCONFIRMED')
? $statuses[0]->name
: $statuses[1]->name;
}
my @groups = $cgi->param('groups');
if ($cloned_bug) {
my @clone_groups = map { $_->name } @{$cloned_bug->groups_in};
# It doesn't matter if there are duplicate names, since all we check
# for in the template is whether or not the group is set.
push(@groups, @clone_groups);
}
$default{'groups'} = \@groups;
$default{'flags'} = [];
$default{'flag_types'} = $product->flag_types->{bug};
Bugzilla::Hook::process('enter_bug_entrydefaultvars', {vars => $vars, default => \%default});
$vars->{'default'} = \%default;
# BMO: add edit_bug_format for the modal UI, just like `show_bug.cgi`
my $format_params = {
format => scalar $cgi->param('format'),
ctype => scalar $cgi->param('ctype'),
};
Bugzilla::Hook::process('enter_bug_format', $format_params);
my $format = $template->get_format(
"bug/create/create",
$format_params->{format},
$format_params->{ctype}
);
print $cgi->header($format->{'ctype'});
$template->process($format->{'template'}, $vars)
|| ThrowTemplateError($template->error());
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。