Closed Bug 180879 Opened 22 years ago Closed 20 years ago

Implement privs for bug flags modification

Categories

(Bugzilla :: Creating/Changing Bugs, enhancement)

2.17.1
enhancement
Not set
normal

Tracking

()

RESOLVED FIXED
Bugzilla 2.20

People

(Reporter: bbaetz, Assigned: LpSolit)

References

(Blocks 2 open bugs)

Details

(Keywords: selenium)

Attachments

(2 files, 9 obsolete files)

This was discussed on irc, but not filed. People w/o editbugs can only edit attachment flags on patches they attached. That got inherited from the old attach status stuff. However, there isn't a corresponding restriction on bug flags. My suggestion is: - require editbugs to +/- a bug flag - assignee can ?/cancel a bug flag Should the reporter be able to make requests? What about the qa contact? I'm leaning towards saying no, and we can always revisit this. Its definately not useful for stuff like approval, which is what bmo will be using it for, but I can imagine it being useful in other contexts. OTOH, such sites can edit the sub in process_bug.
At bmo we are likely to have cases where it makes sense for the reporter to be able to set flags on his bugs. A reporter without edit bugs may use a bug flag like "blocking1.3a" to "nominate" a bug for a particular milestone. I think that a reporter should be able to make this changes to his own bugs. Here's my position: Edit bugs should be required for setting flags. With editbugs a user should be able to set "?", "+", and "-" on any bug. A reporter without editbugs should be able to set and unset "?" in bugs he filed but not set the "+" or "-". Assignee and QA contact should have editbugs so there isn't any problem there. They should be allowed to set any flags if they have editbugs.
We seem to be having problems with this a lot at bmo now. Might be nice to sneak this in before bmo upgrades. There's some cases where it would be useful to assign a group who is allowed to +/- a flag rather than just assuming editbugs (although editbugs could certainly be a default). For example, drivers get to set the blocking flags for Mozilla-related stuff, and there's in theory three people who are allowed to set approval on Bugzilla stuff...
OS: Linux → All
Hardware: PC → All
Target Milestone: --- → Bugzilla 2.18
*** Bug 227573 has been marked as a duplicate of this bug. ***
Assignee: myk → justdave
Flags: blocking2.18+
Status: NEW → ASSIGNED
Summary: Anyone can change bug flags → Implement privs for bug flags modification control
Summary: Implement privs for bug flags modification control → Implement privs for bug flags modification
This would still be nice to have for 2.18, but I'm not going to hold for it. I was planning to do this myself, but I'm probably not going to have time for it in the near future.
Assignee: justdave → nobody
Status: ASSIGNED → NEW
Flags: blocking2.18+ → blocking2.18-
Target Milestone: Bugzilla 2.18 → Bugzilla 2.20
(In reply to comment #1) > Here's my position: > > Edit bugs should be required for setting flags. With editbugs a user should be > able to set "?", "+", and "-" on any bug. > > A reporter without editbugs should be able to set and unset "?" in bugs he filed > but not set the "+" or "-". Why not something like: 1. Reporter and users with canconfirm privs are allowed to set "?". 2. Reporter can unset "?" only if he set "?" himself. 3. Users with canconfirm privs can unset "?" only if they set "?" themselves or the reporter did, but not if it was set by a user with editbugs privs, by the assignee or by the QA contact. 4. Users with editbugs privs can set or unset "?", "-" and "+" flags independently of who set a flag previously. 5. The Assignee and QA contact have the same rights (about flags) as users with canconfirm privs. erik, you said you were interested in taking this bug? ;-)
(In reply to comment #5) > erik, you said you were interested in taking this bug? ;-) I have quite a queue right now. If I run out of things to fix and this one still needs someone, I will probably try it, but that could be several months at least. I don't want to assign it to myself and discourage anyone that wants to fix this right now.
Attached patch restrict bug flag settings (obsolete) — Splinter Review
This patch restricts bug flag modifications as per comment 5. Do not care about the param name 'usereporterrestrictions'. It is because I use the same param as in bug 90619. This is a minor consideration. I hesitate to restrict the "?" status to the reporter, users with canedit and canconfirm privs, as well as the owner and the assignee through 'usereporterrestrictions' and restrict as given by my patch by default (am I clear?? ;-)). justdave, erik, gerv, what do you think about this?
Attached patch restrict bug flag settings, v2 (obsolete) — Splinter Review
Flag settings now do not depend on any parameter. In brief: users with editbugs privs can set/clear any flags ("+", "-" and "?"). QA contact and the owner (assignee) can clear the "?" flag independently of the user who set that flag, but they cannot set/modify the "+" and the "-" flags (except if they have editbugs privs, which is considered first). Any user (including the owner and QA contact) can clear its own flags or set the "?" flag if not yet defined ("X"). That seems a good compromise and also seems to be the minimum we may ask Bugzilla to do.
Attachment #159778 - Attachment is obsolete: true
Comment on attachment 159798 [details] [diff] [review] restrict bug flag settings, v2 justdave, please have a look! It looks like quite reasonable.
Attachment #159798 - Flags: review?(justdave)
hmm, and all the comments we've since made on IRC in discussing this never made it back to it back to the bug :( What's been discussed on IRC is that since different flags are used for different things, it would be much more useful if the privileges could be set on each flag. This would necessitate placing two groups (possibly 3?) on each flag in the editflagtypes.cgi when editing a flag. One group would define who is allowed to request that flag (?), and one would define who is allowed to grant or deny that flag (-/+). The possible third group would define who is able to even see the flag, although that one may make queries darn difficult to enforce, so I'm not too concerned about it.
Attached patch Untested patch, work in progress (obsolete) — Splinter Review
In reply to justdave's comment (also on IRC), I wrote a new patch using groups. Note that this work is still in progress and this patch has not been tested yet! I attach it here to have comments as soon as possible. justdave, is that what you wanted?
Attached patch flag restrictions using groups (obsolete) — Splinter Review
This one is a well tested patch used to restrict flag settings by using groups.
Attachment #159798 - Attachment is obsolete: true
Attachment #159926 - Attachment is obsolete: true
Comment on attachment 160881 [details] [diff] [review] flag restrictions using groups justdave, please review!
Attachment #160881 - Flags: review?(justdave)
Comment on attachment 159798 [details] [diff] [review] restrict bug flag settings, v2 removing review for this patch as specs have changed!
Attachment #159798 - Flags: review?(justdave)
ok, this actually is an enhancement, and we're frozen for 2.20 (likely unfreezing within a week or two when we branch). I'll pounce on this as soon as we branch.
Assignee: nobody → LpSolit
Severity: normal → enhancement
Flags: blocking2.20-
Target Milestone: Bugzilla 2.20 → Bugzilla 2.22
Comment on attachment 160881 [details] [diff] [review] flag restrictions using groups Groups are numbers, not varchars. You need to either store a single group id for each action for each flag or have a flag_group_map that has a row for each group in which the user must be a member to do that particular operation on that particular flag.
Attachment #160881 - Flags: review-
Status: NEW → ASSIGNED
Attachment #160881 - Flags: review?(justdave)
Following my discussion with Joel Peshkin on IRC, some modifications have been made: 1) Store group IDs instead of group names in the DB (to prevent problems when renaming groups); 2) Add the 2 columns 'grant_id' and 'request_id' when upgrading Bugzilla; 3) Warn the user if some flag restrictions depend on groups which are going to be deleted 4) Attachments now also depend on groups for flag settings. I think this patch is now complete and can be reviewed! :)
Attachment #160881 - Attachment is obsolete: true
Comment on attachment 161919 [details] [diff] [review] flag restrictions using groups, v2 justdave, again asking for review (sorry for bugspam). This patch should now be complete!
Attachment #161919 - Flags: review?(justdave)
Attachment #161919 - Flags: review?(myk)
Comment on attachment 161919 [details] [diff] [review] flag restrictions using groups, v2 Anybody else? :)
Attachment #161919 - Flags: review?(bugreport)
Comment on attachment 161919 [details] [diff] [review] flag restrictions using groups, v2 This code looks pretty good. There are a couple issues with it, and I have some style and clarity nits (i.e. optional, but recommended fixes), but overall it's well on its way. > grant_id MEDIUMINT NOT NULL DEFAULT 0 , > request_id MEDIUMINT NOT NULL DEFAULT 0 The "no group" value should be NULL rather than zero. ># Check if the user is allowed to set/modify flags Shouldn't this be part of Flag->validate and FlagType->validate? > my $isqacontact = (($whoid eq $qacontact) && Param('useqacontact')); Nit: check for Param('useqacontact') first. > SendSQL("SELECT type_id, setter_id, status FROM flags WHERE id = $id"); ... > SendSQL("SELECT name, grant_id FROM flagtypes WHERE id = $type_id"); To reduce code duplication it would make sense to create a Flag "object" rather than accessing the flags and flagtypes table directly, even if you only need a subset of the data that the Flag object provides. > my $cangrant = GroupIdToName($grant_id); Nit: this is named similarly to isowner and isqacontact, so it looks like it behaves the same way (i.e. a boolean value defining whether the user can grant a flag, just as isowner defines whether the user is the owner); but in fact it's different, since it contains the name of the group that can grant a flag and is converted to the corresponding boolean value via UserInGroup($cangrant). The naming here should be consistent so that this variable is called f.e. grant_group or $cangrant gets assigned to UserInGroup(GroupIdToName($grant_id)). The same is true for $canrequest. > name of the group allowed to grant/deny flags of this type > (do not specify any group to include all users) "the group allowed to grant/deny flags of this type (to allow all users to grant/deny these flags, leave this empty)" > if requestable, name of the group allowed to request flags of > this type (do not specify any group to include all users) "if flags of this type are requestable, the group allowed to request them (to allow all users to request these flags, leave this empty)" > <input type="text" name="grant_id" value="[% type.grant_id FILTER html %]" size="50" maxlength="255"> > <input type="text" name="request_id" value="[% type.request_id FILTER html %]" size="50" maxlength="255"> Nit: seems like these controls would be better as drop-down menus, but I guess we don't do that elsewhere either, so that's probably the stuff of another bug. > [% IF hasflags %] > <p><b>This group is used to restrict flag settings. You cannot delete > this group while flags use it.</b> > <br><a href="editflagtypes.cgi?action=list&group=[% gid FILTER html %]">Show > me which flags</a> - <input type="checkbox" name="removeflags">Remove all > flag dependencies to this group for me.</p> > <p><b>NOTE:</b> Deleting this group will remove all the corresponding > user restrictions related to these flags.</p> > [% END %] "This group restricts who can make changes to flags of certain types. Show me which types. [] Remove all flag types from this group for me." Also, I'm not sure the "NOTE:" makes sense here. Of the other three relationships between groups and other objects (users, bugs, and products), only bugs has a note, and that's because removing bugs from a group is sufficiently dangerous to warrant extra caution, which is not the case with flags, which are publicly visible even when not modifiable. Also, the note is vague, since it doesn't say what user restrictions are being removed, leaving the user wondering what flag restrictions we refer to. We should either specify exactly what will happen when the user checks that box or not warn the user (in this case probably the latter). > [% ELSIF error == "flag_update_denied" %] > [% title = "Flag Modification Denied" %] > You tried to [% IF status == "+" %] grant [% ELSIF status == "-" %] deny > [% ELSIF status == "X" %] clear [% ELSE %] modify [% END %] the > [% IF type == "b" %][% terms.bug %][% ELSE %] attachment [% END %] flag > <code>[% name FILTER html %]</code>. Only a sufficiently empowered user > [% IF status == "X" %] or the user who set the actual status > <code>[% name FILTER html %][% old_status %]</code>[% END %] is allowed > to change this [% IF type == "b" %][% terms.bug %][% ELSE %] attachment > [% END %] flag to that status. You don't account for requests. Also users never modify both bug and attachment flags simultaneously, so it's not necessary to specify whether the flag was a bug or attachment flag. Also, elsewhere in the code we refer to the flags by flag name only rather than calling them flags, so we should do so here as well, i.e.: "You tried to grant/deny/clear/request <flag name>. Only a sufficiently empowered user |or the user who set <flag name> in the first place| can make this change." > The group [% name FILTER html %] does not exist. Please specifiy specifiy -> specify Otherwise it looks good. I'm not a groups expert, so I may be missing problems with the group code interaction. This should thus be also reviewed by someone with groups knowledge, but that review can be focused on that portion of the code, since I've already done a general review here.
Attachment #161919 - Flags: review?(myk) → review-
Comment on attachment 161919 [details] [diff] [review] flag restrictions using groups, v2 Much better patch coming soon... :)
Attachment #161919 - Flags: review?(justdave)
Attachment #161919 - Flags: review?(bugreport)
Attached patch validation now in Flag*.pm (obsolete) — Splinter Review
This new patch takes into account all remarks from myk. Validation is now made in Flag*.pm which prevents code duplication. I remove the ability for the owner and qa contact to clear the "?" flags. The reasons are: 1) Users in edibugs group which are not in the (flag) grant group could assigned the bug to themselves so that they can clear requests. I don't want that! If they should be able to do so, administrators should put them in the grant group. 2) Users able to request flags are in the (flag) request group. That means they ARE allowed to request and I don't see why the owner or the qa contact who are NOT in the grant group should be able to clear their requests. This is the job of users in the grant group to grant/deny (or clear) flags. Now you understand why I removed this part from my previous patch! ;) It is important to note that due to the inclusion/exclusion lists associated with flag types, and the fact that several flag types may have the same name, users may be in the grant/request groups for some flag types and products but not in others. This allows a better control on who can do what. (such a feature does not exist for the editbugs, i.e on a per product basis. But this is another story ;)).
Attachment #161919 - Attachment is obsolete: true
Comment on attachment 163201 [details] [diff] [review] validation now in Flag*.pm myk, all your comments have been included. Could you please review?
Attachment #163201 - Flags: review?(myk)
Comment on attachment 163201 [details] [diff] [review] validation now in Flag*.pm also asking bugreport to review my patch about the groups part, as suggested by myk.
Attachment #163201 - Flags: review?(bugreport)
Comment on attachment 163201 [details] [diff] [review] validation now in Flag*.pm Hmm, this looks good. My only nit is that grant_id and request_id would probably make more sense as grant_group_id and request_group_id, since although these names are unwieldy they follow the common Bugzilla practice of naming foreign keys after the tables to which they're related. r=myk
Attachment #163201 - Flags: review?(myk) → review+
Comment on attachment 163201 [details] [diff] [review] validation now in Flag*.pm With a few exceptions, this looks good (still need to test it, of course)... >+ # - The flag is unchanged >+ next if ($status eq $flag->{status}); >+ >+ # - User can clear flags set by itself >+ next if (($status eq "X") && ($::userid eq $flag->{setter})); >+ >+ # - User in the $grant_id group can set/clear flags, >+ # including "+" and "-" >+ next if (!$flag->{type}->{grant_id} || >+ &::UserInGroup(&::GroupIdToName($flag->{type}->{grant_id}))); >+ get rid of the globals ($::userid) should be replaced by looking up $user = Bugzilla->user and then using $user->id for the userid and checking for a group is done using Bugzilla->user->groups->{name} [ or $user->in_group(name) ] to check on group membership. Essentially, any time you see a "::" in your patch, you are putting something in that we are trying to eradicate.
Attachment #163201 - Flags: review?(bugreport) → review-
(In reply to comment #26) > &::UserInGroup(&::GroupIdToName($flag->{type}->{grant_id}))); > Essentially, any time you see a "::" in your patch, > you are putting something in that we are trying to eradicate. Except that GroupIdToName doesn't have an alternative that I see, so you can go on using it.
OK, fair enough. Later, let's add a mechanism to confirm group membership by group id in User.pm
Attached patch validation now in Flag*.pm, v2 (obsolete) — Splinter Review
Including myk's and bugreport's comments: grant_id -> grant_group_id request_id -> request_group_id $::userid -> Bugzilla->user->id &::UserInGroup -> Bugzilla->user->in_group() + add a comment when editing flag types that the request group has no effect if the grant group is not defined (for obvious reasons).
Attachment #163201 - Attachment is obsolete: true
Comment on attachment 164780 [details] [diff] [review] validation now in Flag*.pm, v2 few modifications compared to the previous one.
Attachment #164780 - Flags: review?(myk)
Attachment #164780 - Flags: review?(bugreport)
Comment on attachment 164780 [details] [diff] [review] validation now in Flag*.pm, v2 This is failing runtests (filter violations). I'm also getting some runtime errors on my test install, but that may well be unrelated.
Attachment #164780 - Flags: review?(bugreport) → review-
Thanks to joel who noticed that I forgot to filter old_status in an error message. [% old_status FILTER html %] is now correct and runtests.sh does not complain anymore.
Attachment #164780 - Attachment is obsolete: true
Attachment #164780 - Flags: review?(myk)
Attachment #166593 - Flags: review?(myk)
Attachment #166593 - Flags: review?(bugreport)
Attachment #166593 - Flags: review?(bugreport) → review+
Flags: approval?
This is actually a pretty high-impact high-gain patch, and since we haven't actually branched yet, let's go ahead and throw this into 2.20.
Flags: approval? → approval+
Target Milestone: Bugzilla 2.22 → Bugzilla 2.20
Checking in checksetup.pl; /cvsroot/mozilla/webtools/bugzilla/checksetup.pl,v <-- checksetup.pl new revision: 1.313; previous revision: 1.312 done Checking in editflagtypes.cgi; /cvsroot/mozilla/webtools/bugzilla/editflagtypes.cgi,v <-- editflagtypes.cgi new revision: 1.10; previous revision: 1.9 done Checking in editgroups.cgi; /cvsroot/mozilla/webtools/bugzilla/editgroups.cgi,v <-- editgroups.cgi new revision: 1.43; previous revision: 1.42 done Checking in Bugzilla/Flag.pm; /cvsroot/mozilla/webtools/bugzilla/Bugzilla/Flag.pm,v <-- Flag.pm new revision: 1.23; previous revision: 1.22 done Checking in Bugzilla/FlagType.pm; /cvsroot/mozilla/webtools/bugzilla/Bugzilla/FlagType.pm,v <-- FlagType.pm new revision: 1.10; previous revision: 1.9 done Checking in template/en/default/admin/flag-type/edit.html.tmpl; /cvsroot/mozilla/webtools/bugzilla/template/en/default/admin/flag-type/edit.html.tmpl,v <-- edit.html.tmpl new revision: 1.8; previous revision: 1.7 done Checking in template/en/default/admin/groups/delete.html.tmpl; /cvsroot/mozilla/webtools/bugzilla/template/en/default/admin/groups/delete.html.tmpl,v <-- delete.html.tmpl new revision: 1.3; previous revision: 1.2 done Checking in template/en/default/global/user-error.html.tmpl; /cvsroot/mozilla/webtools/bugzilla/template/en/default/global/user-error.html.tmpl,v <-- user-error.html.tmpl new revision: 1.75; previous revision: 1.74 done
Status: ASSIGNED → RESOLVED
Closed: 20 years ago
Resolution: --- → FIXED
Attachment #166593 - Flags: review?(myk)
Flags: documentation?
Blocks: 275608
Blocks: 275610
Blocks: 275611
Blocks: 288603
Attachment #214033 - Flags: review? → review?(documentation)
Comment on attachment 214033 [details] [diff] [review] docs patch about 'Bugzilla Database Tables' section, for 2.18 this has nothing to do in this bug IMO. Moreover, you mention tables which do not appear in the figure above it. This bug was about the grant_group_id and request_group_id fields of the flagtypes table.
Attachment #214033 - Flags: review?(documentation) → review-
Attachment #214033 - Attachment is obsolete: true
Attached patch documentation patch, v1 (obsolete) — Splinter Review
Attachment #246081 - Flags: review?(myk)
Comment on attachment 246081 [details] [diff] [review] documentation patch, v1 >Index: docs/xml/administration.xml >=================================================================== >RCS file: /cvsroot/mozilla/webtools/bugzilla/docs/xml/administration.xml,v >retrieving revision 1.62 >diff -3 -p -u -r1.62 administration.xml >--- docs/xml/administration.xml 13 Nov 2006 23:32:28 -0000 1.62 >+++ docs/xml/administration.xml 20 Nov 2006 22:30:48 -0000 >@@ -880,9 +880,9 @@ > <section id="flag-askto"> > <title>Using flag requests</title> > <para> >- If a flag has been defined as 'requestable', >- users are allowed to set the flag's status to <quote>?</quote>. >- This status indicates that someone (aka <quote>the requester</quote> is asking >+ If a flag has been defined as 'requestable', and a user has enough privileges >+ to request it (see below), the user can set the flag's status to <quote>?</quote>. >+ This status indicates that someone (aka <quote>the requester</quote>) is asking > for someone else to set the flag to either <quote>+</quote> or <quote>-</quote>. Nits: aka -> a.k.a. for someone else -> someone else (I realize these are both in the current version.) >+ <listitem> >+ <para> >+ Requests are listed in the <quote>Request Queue</quote> which >+ is accessible from the <quote>My Requests</quote> (if you are >+ logged in) or <quote>Requests</quote> (if you are logged out) >+ link visible in the footer of all pages. >+ </para> >+ </listitem> <quote>Request Queue</quote> which -> <quote>Request Queue</quote>, which Nit: <quote>My Requests</quote> (if you are logged in) or <quote>Requests</quote> (if you are logged out) link -> <quote>My Requests</quote> link (if you are logged in) or <quote>Requests</quote> link (if you are logged out) > Bug flags are used to set a status on the bug itself. You can >- see Bug Flags in the <quote>Show Bug</quote> screen >- (<filename>editbug.cgi</filename>). >+ see Bug Flags in the <quote>Show Bug</quote> and <quote>Requests</quote> >+ screen, as above. screen -> screens What does "as above" mean? Perhaps you mean "as described above"? >- The name may consist of any valid Unicode character. >+ The name may consist of any valid Unicode character, except commas >+ and spaces. Nit: consist of -> contain Nit: character -> characters Nit: , except -> except ? >- This describes the flag in more detail. At present, this doesn't >- show up anywhere helpful; ideally, it would be nice to have >- it show up as a tooltip. This field >- can be as long as you like, and can contain any character you want. >+ This describes the flag in more detail. This description is visible >+ in a tooltip when hovering over a flag either in the "Show Bug" or >+ "Edit Attachment" pages. This field can be as long as you like, >+ and can contain any character you want. Nit: This describes the flag in more detail. This description is visible -> The description describes the flag in more detail. It is visible "Show Bug" or "Edit Attachment" -> <quote>Show Bug</quote> or <quote>Edit Attachment</quote> ? > You may select a Product without selecting a specific Component, > but it is illegal to select a Component without a Product, or to select a >- Component that does not belong to the named Product. Doing so as of >- this writing (2.18rc3) will raise an error... even if all your products >- have a component by that name. >+ Component that does not belong to the named Product. Doing so will raise >+ an error... even if all your products have a component by that name. but it is illegal to select -> but you can't select The last sentence should read: If you do so, Bugzilla will display an error message, even if all your products have a component by that name. We should really fix this. >- of the same type will appear below it with <quote>addl.</quote> (short for >+ of the same type will appear below it with <quote>addl.</quote> (short for Trailing space removal? >+ <section id="flags-create-field-cclist"> >+ <title>CC List</title> >+ >+ <para> >+ If you want certain users to be notified every time this flag is >+ set to ?, -, +, or unset, add them here. This is a comma-separated >+ list of email addresses that need not be restricted to Bugzilla usernames.. .. -> . >+ <section id="flags-create-grant-group"> >+ <title>Grant Group</title> >+ <para> >+ When this field is set to some given group, only users in this group >+ can set the flag to <quote>+</quote> and <quote>-</quote>. These users >+ can also do requests as well as cancelling the flag. If this field >+ is left blank, all users can set or delete this flag. This feature >+ is very useful when you want to restrict who is allowed to decide >+ whether a request should be approved or rejected. do requests -> request cancelling -> canceling ? Nit: only users in this group -> only users in the group Nit: These users can also do requests as well as canceling the flag. -> This field does not affect who can request or cancel the flag. For that, see the <quote>Request Group</quote> field below. Nit: This feature is very useful when you want to restrict who is allowed to decide whether a request should be approved or rejected. -> This field is useful for restricting which users can approve or reject requests. >+ <section id="flags-create-request-group"> >+ <title>Request Group</title> >+ <para> >+ When this field is set to some given group, only users in this group >+ can do requests for this flag, unless the <quote>grant group</quote> >+ is empty, in which case this field has no effect. Combined with the >+ <quote>grant group</quote>, this lets you have a delimited group >+ of users who can do requests, which can be the same group as those >+ who can do approvals or not. Also, all users in the <quote>request >+ group</quote> can cancel any flag, independently of its status. I think this reads better as: When this field is set to some given group, only users in the group can request or cancel this flag. Note that this field has no effect if the <quote>grant group</quote> field is empty. You can set the value of this field to a different group, but both fields have to be set to a group for this field to have an effect.
Attachment #246081 - Flags: review?(myk) → review-
All comments and nits fixed.
Attachment #246081 - Attachment is obsolete: true
Attachment #246136 - Flags: review?(myk)
Comment on attachment 246136 [details] [diff] [review] documentation patch, v2 + <title>Grant Group</title> + useful for restricting which users can approve or reject requests. not grant?
Attachment #246136 - Flags: review?(myk) → review+
tip: Checking in docs/xml/administration.xml; /cvsroot/mozilla/webtools/bugzilla/docs/xml/administration.xml,v <-- administration.xml new revision: 1.63; previous revision: 1.62 done 2.22.1: Checking in docs/xml/administration.xml; /cvsroot/mozilla/webtools/bugzilla/docs/xml/administration.xml,v <-- administration.xml new revision: 1.55.2.4; previous revision: 1.55.2.3 done 2.20.3: Checking in docs/xml/administration.xml; /cvsroot/mozilla/webtools/bugzilla/docs/xml/administration.xml,v <-- administration.xml new revision: 1.50.2.7; previous revision: 1.50.2.6 done
Flags: testcase?
Flags: documentation?
Flags: documentation2.22+
Flags: documentation2.20+
Flags: documentation+
Keywords: selenium
Flags: testcase? → testcase+
QA Contact: matty_is_a_geek → default-qa
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: