192 lines
5.2 KiB
Perl
Executable File
192 lines
5.2 KiB
Perl
Executable File
#!/usr/bin/perl -T
|
|
# 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.
|
|
|
|
use 5.10.1;
|
|
use strict;
|
|
use warnings;
|
|
|
|
use lib qw(. lib);
|
|
|
|
use Bugzilla;
|
|
use Bugzilla::Util;
|
|
use Bugzilla::Error;
|
|
use Bugzilla::Constants;
|
|
use Bugzilla::Token;
|
|
use Bugzilla::Field;
|
|
use Bugzilla::Field::Choice;
|
|
|
|
###############
|
|
# Subroutines #
|
|
###############
|
|
|
|
sub display_field_values {
|
|
my $vars = shift;
|
|
my $template = Bugzilla->template;
|
|
$vars->{'values'} = $vars->{'field'}->legal_values;
|
|
$template->process("admin/fieldvalues/list.html.tmpl", $vars)
|
|
|| ThrowTemplateError($template->error());
|
|
exit;
|
|
}
|
|
|
|
######################################################################
|
|
# Main Body Execution
|
|
######################################################################
|
|
|
|
# require the user to have logged in
|
|
my $user = Bugzilla->login(LOGIN_REQUIRED);
|
|
|
|
my $dbh = Bugzilla->dbh;
|
|
my $cgi = Bugzilla->cgi;
|
|
my $template = Bugzilla->template;
|
|
my $vars = {};
|
|
|
|
# Replace this entry by separate entries in templates when
|
|
# the documentation about legal values becomes bigger.
|
|
$vars->{'doc_section'} = 'administering/field-values.html';
|
|
|
|
print $cgi->header();
|
|
|
|
$user->in_group('admin')
|
|
|| ThrowUserError('auth_failure', {group => "admin",
|
|
action => "edit",
|
|
object => "field_values"});
|
|
|
|
#
|
|
# often-used variables
|
|
#
|
|
my $action = trim($cgi->param('action') || '');
|
|
my $token = $cgi->param('token');
|
|
|
|
#
|
|
# field = '' -> Show nice list of fields
|
|
#
|
|
if (!$cgi->param('field')) {
|
|
my @field_list =
|
|
@{ Bugzilla->fields({ is_select => 1, is_abnormal => 0 }) };
|
|
|
|
$vars->{'fields'} = \@field_list;
|
|
$template->process("admin/fieldvalues/select-field.html.tmpl", $vars)
|
|
|| ThrowTemplateError($template->error());
|
|
exit;
|
|
}
|
|
|
|
# At this point, the field must be defined.
|
|
my $field = Bugzilla::Field->check($cgi->param('field'));
|
|
if (!$field->is_select || $field->is_abnormal) {
|
|
ThrowUserError('fieldname_invalid', { field => $field });
|
|
}
|
|
$vars->{'field'} = $field;
|
|
|
|
#
|
|
# action='' -> Show nice list of values.
|
|
#
|
|
display_field_values($vars) unless $action;
|
|
|
|
#
|
|
# action='add' -> show form for adding new field value.
|
|
# (next action will be 'new')
|
|
#
|
|
if ($action eq 'add') {
|
|
$vars->{'token'} = issue_session_token('add_field_value');
|
|
$template->process("admin/fieldvalues/create.html.tmpl", $vars)
|
|
|| ThrowTemplateError($template->error());
|
|
exit;
|
|
}
|
|
|
|
#
|
|
# action='new' -> add field value entered in the 'action=add' screen
|
|
#
|
|
if ($action eq 'new') {
|
|
check_token_data($token, 'add_field_value');
|
|
|
|
my $created_value = Bugzilla::Field::Choice->type($field)->create({
|
|
value => scalar $cgi->param('value'),
|
|
sortkey => scalar $cgi->param('sortkey'),
|
|
is_open => scalar $cgi->param('is_open'),
|
|
visibility_value_id => scalar $cgi->param('visibility_value_id'),
|
|
});
|
|
|
|
delete_token($token);
|
|
|
|
$vars->{'message'} = 'field_value_created';
|
|
$vars->{'value'} = $created_value;
|
|
display_field_values($vars);
|
|
}
|
|
|
|
# After this, we always have a value
|
|
my $value = Bugzilla::Field::Choice->type($field)->check($cgi->param('value'));
|
|
$vars->{'value'} = $value;
|
|
|
|
#
|
|
# action='del' -> ask if user really wants to delete
|
|
# (next action would be 'delete')
|
|
#
|
|
if ($action eq 'del') {
|
|
# If the value cannot be deleted, throw an error.
|
|
if ($value->is_static) {
|
|
ThrowUserError('fieldvalue_not_deletable', $vars);
|
|
}
|
|
$vars->{'token'} = issue_session_token('delete_field_value');
|
|
|
|
$template->process("admin/fieldvalues/confirm-delete.html.tmpl", $vars)
|
|
|| ThrowTemplateError($template->error());
|
|
|
|
exit;
|
|
}
|
|
|
|
|
|
#
|
|
# action='delete' -> really delete the field value
|
|
#
|
|
if ($action eq 'delete') {
|
|
check_token_data($token, 'delete_field_value');
|
|
$value->remove_from_db();
|
|
delete_token($token);
|
|
$vars->{'message'} = 'field_value_deleted';
|
|
$vars->{'no_edit_link'} = 1;
|
|
display_field_values($vars);
|
|
}
|
|
|
|
|
|
#
|
|
# action='edit' -> present the edit-value form
|
|
# (next action would be 'update')
|
|
#
|
|
if ($action eq 'edit') {
|
|
$vars->{'token'} = issue_session_token('edit_field_value');
|
|
$template->process("admin/fieldvalues/edit.html.tmpl", $vars)
|
|
|| ThrowTemplateError($template->error());
|
|
|
|
exit;
|
|
}
|
|
|
|
|
|
#
|
|
# action='update' -> update the field value
|
|
#
|
|
if ($action eq 'update') {
|
|
check_token_data($token, 'edit_field_value');
|
|
$vars->{'value_old'} = $value->name;
|
|
my %params = (
|
|
name => scalar $cgi->param('value_new'),
|
|
sortkey => scalar $cgi->param('sortkey'),
|
|
visibility_value => scalar $cgi->param('visibility_value_id'),
|
|
);
|
|
if ($cgi->should_set('is_active')) {
|
|
$params{is_active} = $cgi->param('is_active');
|
|
}
|
|
$value->set_all(\%params);
|
|
$vars->{'changes'} = $value->update();
|
|
delete_token($token);
|
|
$vars->{'message'} = 'field_value_updated';
|
|
display_field_values($vars);
|
|
}
|
|
|
|
# No valid action found
|
|
ThrowUserError('unknown_action', {action => $action});
|