Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
bugzilla
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Ivan Ivlev
bugzilla
Commits
0d39e7b4
Commit
0d39e7b4
authored
Jun 25, 2010
by
Max Kanat-Alexander
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 573173: Make Bugzilla::Bug's add_group and remove_group take group
names instead of ids r=dkl, a=mkanat
parent
ed5c3b39
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
53 additions
and
59 deletions
+53
-59
Bug.pm
Bugzilla/Bug.pm
+6
-8
process_bug.cgi
process_bug.cgi
+4
-21
edit.html.tmpl
template/en/default/bug/edit.html.tmpl
+5
-4
verify-new-product.html.tmpl
template/en/default/bug/process/verify-new-product.html.tmpl
+17
-16
user-error.html.tmpl
template/en/default/global/user-error.html.tmpl
+4
-4
edit-multiple.html.tmpl
template/en/default/list/edit-multiple.html.tmpl
+17
-6
No files found.
Bugzilla/Bug.pm
View file @
0d39e7b4
...
@@ -2682,8 +2682,7 @@ sub add_group {
...
@@ -2682,8 +2682,7 @@ sub add_group {
my
(
$self
,
$group
)
=
@_
;
my
(
$self
,
$group
)
=
@_
;
# Invalid ids are silently ignored. (We can't tell people whether
# Invalid ids are silently ignored. (We can't tell people whether
# or not a group exists.)
# or not a group exists.)
$group
=
new
Bugzilla::
Group
(
$group
)
unless
ref
$group
;
$group
=
Bugzilla::
Group
->
check
(
$group
)
if
!
blessed
$group
;
return
unless
$group
;
return
if
!
$group
->
is_active
or
!
$group
->
is_bug_group
;
return
if
!
$group
->
is_active
or
!
$group
->
is_bug_group
;
...
@@ -2691,7 +2690,7 @@ sub add_group {
...
@@ -2691,7 +2690,7 @@ sub add_group {
# to this group by the current user.
# to this group by the current user.
$self
->
product_obj
->
group_is_settable
(
$group
)
$self
->
product_obj
->
group_is_settable
(
$group
)
||
ThrowUserError
(
'group_invalid_restriction'
,
||
ThrowUserError
(
'group_invalid_restriction'
,
{
product
=>
$self
->
product
,
group
_id
=>
$group
->
id
,
{
product
=>
$self
->
product
,
group
=>
$group
,
bug
=>
$self
});
bug
=>
$self
});
# OtherControl people can add groups only during a product change,
# OtherControl people can add groups only during a product change,
...
@@ -2702,7 +2701,7 @@ sub add_group {
...
@@ -2702,7 +2701,7 @@ sub add_group {
||
$controls
->
{
othercontrol
}
==
CONTROLMAPNA
)
||
$controls
->
{
othercontrol
}
==
CONTROLMAPNA
)
{
{
ThrowUserError
(
'group_change_denied'
,
ThrowUserError
(
'group_change_denied'
,
{
bug
=>
$self
,
group
_id
=>
$group
->
id
});
{
bug
=>
$self
,
group
=>
$group
});
}
}
}
}
...
@@ -2714,8 +2713,7 @@ sub add_group {
...
@@ -2714,8 +2713,7 @@ sub add_group {
sub
remove_group
{
sub
remove_group
{
my
(
$self
,
$group
)
=
@_
;
my
(
$self
,
$group
)
=
@_
;
$group
=
new
Bugzilla::
Group
(
$group
)
unless
ref
$group
;
$group
=
Bugzilla::
Group
->
check
(
$group
)
if
!
blessed
$group
;
return
unless
$group
;
# First, check if this is a valid group for this product.
# First, check if this is a valid group for this product.
# You can *always* remove a group that is not valid for this product
# You can *always* remove a group that is not valid for this product
...
@@ -2731,7 +2729,7 @@ sub remove_group {
...
@@ -2731,7 +2729,7 @@ sub remove_group {
# Nobody can ever remove a Mandatory group.
# Nobody can ever remove a Mandatory group.
if
(
$controls
->
{
membercontrol
}
==
CONTROLMAPMANDATORY
)
{
if
(
$controls
->
{
membercontrol
}
==
CONTROLMAPMANDATORY
)
{
ThrowUserError
(
'group_invalid_removal'
,
ThrowUserError
(
'group_invalid_removal'
,
{
product
=>
$self
->
product
,
group
_id
=>
$group
->
id
,
{
product
=>
$self
->
product
,
group
=>
$group
,
bug
=>
$self
});
bug
=>
$self
});
}
}
...
@@ -2743,7 +2741,7 @@ sub remove_group {
...
@@ -2743,7 +2741,7 @@ sub remove_group {
||
$controls
->
{
othercontrol
}
==
CONTROLMAPNA
)
||
$controls
->
{
othercontrol
}
==
CONTROLMAPNA
)
{
{
ThrowUserError
(
'group_change_denied'
,
ThrowUserError
(
'group_change_denied'
,
{
bug
=>
$self
,
group
_id
=>
$group
->
id
});
{
bug
=>
$self
,
group
=>
$group
});
}
}
}
}
}
}
...
...
process_bug.cgi
View file @
0d39e7b4
...
@@ -337,27 +337,10 @@ foreach my $field (grep(/^defined_isprivate/, $cgi->param())) {
...
@@ -337,27 +337,10 @@ foreach my $field (grep(/^defined_isprivate/, $cgi->param())) {
}
}
$set_all_fields
{
comment_is_private
}
=
\%
is_private
;
$set_all_fields
{
comment_is_private
}
=
\%
is_private
;
my
%
groups
=
(
add
=>
[]
,
remove
=>
[]
);
my
@check_groups
=
$cgi
->
param
(
'defined_groups'
);
my
%
checked_bit
;
# Used to avoid adding groups twice (defined_ + actual bit-)
my
@set_groups
=
$cgi
->
param
(
'groups'
);
foreach
my
$param_name
(
grep
(
/bit-\d+$/
,
$cgi
->
param
()))
{
my
(
$removed_groups
)
=
diff_arrays
(
\
@check_groups
,
\
@set_groups
);
$param_name
=~
/bit-(\d+)$/
;
$set_all_fields
{
groups
}
=
{
add
=>
\
@set_groups
,
remove
=>
$removed_groups
};
my
$gid
=
$1
;
next
if
$checked_bit
{
$gid
};
my
$bit_param
=
"bit-$gid"
;
if
(
should_set
(
$bit_param
,
1
))
{
# Check ! first to avoid having to check defined below.
if
(
!
$cgi
->
param
(
$bit_param
))
{
push
(
@
{
$groups
{
remove
}
},
$gid
);
}
# "== 1" is important because mass-change uses -1 to mean
# "don't change this restriction"
elsif
(
$cgi
->
param
(
$bit_param
)
==
1
)
{
push
(
@
{
$groups
{
add
}
},
$gid
);
}
}
$checked_bit
{
$gid
}
=
1
;
}
$set_all_fields
{
groups
}
=
\%
groups
;
my
@custom_fields
=
Bugzilla
->
active_custom_fields
;
my
@custom_fields
=
Bugzilla
->
active_custom_fields
;
foreach
my
$field
(
@custom_fields
)
{
foreach
my
$field
(
@custom_fields
)
{
...
...
template/en/default/bug/edit.html.tmpl
View file @
0d39e7b4
...
@@ -654,14 +654,15 @@
...
@@ -654,14 +654,15 @@
[% END %]
[% END %]
[% IF group.ingroup %]
[% IF group.ingroup %]
<input type="hidden" name="defined_bit-[% group.bit %]" value="1">
<input type="hidden" name="defined_groups"
value="[% group.name FILTER html %]">
[% END %]
[% END %]
<input type="checkbox" value="
1" name="bit-[% group.bit %]"
<input type="checkbox" value="
[% group.name FILTER html %]"
id="bit-
[% group.bit %]"
name="groups" id="group_
[% group.bit %]"
[% ' checked="checked"' IF group.ison %]
[% ' checked="checked"' IF group.ison %]
[% ' disabled="disabled"' IF NOT group.ingroup %]>
[% ' disabled="disabled"' IF NOT group.ingroup %]>
<label for="
bit-
[% group.bit %]">
<label for="
group_
[% group.bit %]">
[%- group.description FILTER html_light %]</label>
[%- group.description FILTER html_light %]</label>
<br>
<br>
[% END %]
[% END %]
...
...
template/en/default/bug/process/verify-new-product.html.tmpl
View file @
0d39e7b4
...
@@ -40,7 +40,7 @@
...
@@ -40,7 +40,7 @@
[% SET exclude_items = ['version', 'component', 'target_milestone'] %]
[% SET exclude_items = ['version', 'component', 'target_milestone'] %]
[% IF verify_bug_groups %]
[% IF verify_bug_groups %]
[% exclude_items.push('
bit-\d+
') %]
[% exclude_items.push('
groups', 'defined_groups
') %]
[% END %]
[% END %]
[% Hook.process('exclude') %]
[% Hook.process('exclude') %]
...
@@ -124,9 +124,10 @@
...
@@ -124,9 +124,10 @@
[%+ terms.Bugs %] will no longer be restricted to these groups and may become
[%+ terms.Bugs %] will no longer be restricted to these groups and may become
public if no other group applies:<br>
public if no other group applies:<br>
[% FOREACH group = old_groups %]
[% FOREACH group = old_groups %]
<input type="checkbox" id="bit-[% group.id FILTER html %]"
<input type="checkbox" id="group_[% group.group.id FILTER html %]"
name="bit-[% group.id FILTER html %]" disabled="disabled" value="1">
name="groups" disabled="disabled"
<label for="bit-[% group.id FILTER html %]">
value="[% group.group.name FILTER html %]">
<label for="group_[% group.group.id FILTER html %]">
[% group.name FILTER html %]: [% group.description FILTER html %]
[% group.name FILTER html %]: [% group.description FILTER html %]
</label>
</label>
<br>
<br>
...
@@ -154,16 +155,15 @@
...
@@ -154,16 +155,15 @@
<p>These groups are optional. You can decide to restrict [% terms.bugs %] to
<p>These groups are optional. You can decide to restrict [% terms.bugs %] to
one or more of the following groups:<br>
one or more of the following groups:<br>
[% FOREACH group = optional_groups %]
[% FOREACH group = optional_groups %]
<input type="hidden" name="defined_
bit-[% group.group.id FILTER html %]
"
<input type="hidden" name="defined_
groups
"
value="
1
">
value="
[% group.group.name FILTER html %]
">
<input type="checkbox" id="
bit-
[% group.group.id FILTER html %]"
<input type="checkbox" id="
group_
[% group.group.id FILTER html %]"
name="
bit-[% group.group.id FILTER html %]
"
name="
groups
"
[%
+
((group.membercontrol == constants.CONTROLMAPDEFAULT && user.in_group(group.group.name))
[%
' checked="checked"' IF
((group.membercontrol == constants.CONTROLMAPDEFAULT && user.in_group(group.group.name))
|| (group.othercontrol == constants.CONTROLMAPDEFAULT && !user.in_group(group.group.name))
|| (group.othercontrol == constants.CONTROLMAPDEFAULT && !user.in_group(group.group.name))
|| cgi.param("bit-$group.group.id") == 1) ?
|| cgi.param("groups").contains(group.group.name)) %]
'checked="checked"' : ''
%] value="[% group.group.name FILTER html %]">
%] value="1">
<label for="group_[% group.group.id FILTER html %]">
<label for="bit-[% group.group.id FILTER html %]">
[% group.group.name FILTER html %]: [% group.group.description FILTER html %]
[% group.group.name FILTER html %]: [% group.group.description FILTER html %]
</label>
</label>
<br>
<br>
...
@@ -175,9 +175,10 @@
...
@@ -175,9 +175,10 @@
<p>These groups are mandatory and [% terms.bugs %] will be automatically
<p>These groups are mandatory and [% terms.bugs %] will be automatically
restricted to these groups:<br>
restricted to these groups:<br>
[% FOREACH group = mandatory_groups %]
[% FOREACH group = mandatory_groups %]
<input type="checkbox" id="bit-[% group.group.id FILTER html %]" checked="checked"
<input type="checkbox" id="group_[% group.group.id FILTER html %]"
name="bit-[% group.group.id FILTER html %]" value="1" disabled="disabled">
checked="checked" disabled="disabled"
<label for="bit-[% group.group.id FILTER html %]">
name="groups" value="[% group.group.name FILTER html %]">
<label for="group_[% group.group.id FILTER html %]">
[% group.group.name FILTER html %]: [% group.group.description FILTER html %]
[% group.group.name FILTER html %]: [% group.group.description FILTER html %]
</label>
</label>
<br>
<br>
...
...
template/en/default/global/user-error.html.tmpl
View file @
0d39e7b4
...
@@ -701,7 +701,7 @@
...
@@ -701,7 +701,7 @@
[% ELSIF error == "group_change_denied" %]
[% ELSIF error == "group_change_denied" %]
[% title = "Cannot Add/Remove That Group" %]
[% title = "Cannot Add/Remove That Group" %]
You tried to add or remove
group id [% group_id FILTER html %]
You tried to add or remove
the '[% group.name FILTER html %]' group
from [% terms.bug %] [%+ bug.id FILTER html %], but you do not
from [% terms.bug %] [%+ bug.id FILTER html %], but you do not
have permissions to do so.
have permissions to do so.
...
@@ -726,13 +726,13 @@
...
@@ -726,13 +726,13 @@
[% ELSIF error == "group_invalid_removal" %]
[% ELSIF error == "group_invalid_removal" %]
You tried to remove [% terms.bug %] [%+ bug.id FILTER html %]
You tried to remove [% terms.bug %] [%+ bug.id FILTER html %]
from
group id [% group_id FILTER html %], but [% terms.bugs %] in the
from
the '[% group.name FILTER html %]' group, but [% terms.bugs %]
'[% product FILTER html %]' product can not be removed from that
in the
'[% product FILTER html %]' product can not be removed from that
group.
group.
[% ELSIF error == "group_invalid_restriction" %]
[% ELSIF error == "group_invalid_restriction" %]
You tried to restrict [% terms.bug %] [%+ bug.id FILTER html %] to
You tried to restrict [% terms.bug %] [%+ bug.id FILTER html %] to
to
group id [% group_id FILTER html %]
, but [% terms.bugs %] in the
to
the '[% group.name FILTER html %]' group
, but [% terms.bugs %] in the
'[% product FILTER html %]' product can not be restricted to
'[% product FILTER html %]' product can not be restricted to
that group.
that group.
...
...
template/en/default/list/edit-multiple.html.tmpl
View file @
0d39e7b4
...
@@ -309,10 +309,18 @@
...
@@ -309,10 +309,18 @@
[% IF groups.size > 0 %]
[% IF groups.size > 0 %]
<script type="text/javascript">
function turn_off(myself, id) {
var other_checkbox = document.getElementById(id);
if (myself.checked && other_checkbox) {
other_checkbox.checked = false;
}
}
</script>
<b>Groups:</b><br>
<b>Groups:</b><br>
<table border="1">
<table border="1">
<tr>
<tr>
<th>Don't<br>change<br>this group<br>restriction</th>
<th>Remove<br>[% terms.bugs %]<br>from this<br>group</th>
<th>Remove<br>[% terms.bugs %]<br>from this<br>group</th>
<th>Add<br>[% terms.bugs %]<br>to this<br>group</th>
<th>Add<br>[% terms.bugs %]<br>to this<br>group</th>
<th>Group Name:</th>
<th>Group Name:</th>
...
@@ -321,14 +329,17 @@
...
@@ -321,14 +329,17 @@
[% FOREACH group = groups %]
[% FOREACH group = groups %]
<tr>
<tr>
<td align="center">
<td align="center">
<input type="
radio" name="bit-[% group.id %]" value="-1" checked="checked">
<input type="
checkbox" name="defined_groups"
</td>
id="defined_group_[% group.id %]"
<td align="center">
value="[% group.name FILTER html %]"
<input type="radio" name="bit-[% group.id %]" value="0
">
onchange="turn_off(this, 'group_[% group.id %]')
">
</td>
</td>
[% IF group.is_active %]
[% IF group.is_active %]
<td align="center">
<td align="center">
<input type="radio" name="bit-[% group.id %]" value="1">
<input type="checkbox" name="groups"
id="group_[% group.id FILTER html %]"
value="[% group.name FILTER html %]"
onchange="turn_off(this, 'defined_group_[% group.id %]')">
</td>
</td>
[% ELSE %]
[% ELSE %]
<td> </td>
<td> </td>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment