1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
<& /Admin/Elements/Header, Title => 'Modify group rights for queue '. $QueueObj->Name &>
<& /Admin/Elements/QueueTabs, id => $id &>
<& /Elements/ListActions, actions => \@results &>
<FORM METHOD=POST ACTION="GroupRights.html">
<INPUT TYPE=HIDDEN NAME=id VALUE="<% $QueueObj->id %>">
<& /Elements/TitleBoxStart, title => 'Modify group rights for queue '.$QueueObj->Name &>
<TABLE>
<TR><TD>Pseudogroups</TD></TR>
% while (my $GroupObj = $PseudoGroups->Next()) {
<TR ALIGN=RIGHT>
<TD VALIGN=TOP>
<% $GroupObj->Name %>
</TD>
<TD>
<& /Admin/Elements/SelectRights, PrincipalObj => $GroupObj,
PrincipalType => 'Group',
QueueObj => $QueueObj,
Scope => 'Queue' &>
</TD>
</TR>
% }
<TR><TD>Groups</TD></TR>
% while (my $GroupObj = $Groups->Next()) {
<TR ALIGN=RIGHT>
<TD VALIGN=TOP>
<% $GroupObj->Name %>
</TD>
<TD>
<& /Admin/Elements/SelectRights, PrincipalObj => $GroupObj,
PrincipalType => 'Group',
QueueObj => $QueueObj,
Scope => 'Queue' &>
</TD>
</TR>
% }
</TABLE>
<& /Elements/TitleBoxEnd &>
<& /Elements/Submit, Caption => "Be sure to save your changes", Reset => 1 &>
</FORM>
<%INIT>
#Update the acls.
my @results = ProcessACLChanges(\@CheckACL, \%ARGS);
# {{{ Deal with setting up the display of current rights.
# {{{ do basic initialization.
#Define vars used in html above
my ($GroupObj);
my ($right);
if (!defined $id) {
Abort("No Queue defined");
}
my $QueueObj = new RT::Queue($session{'CurrentUser'});
$QueueObj->Load($id) ||
Abort("Couldn't load queue $id");
# Find out which groups we want to display ACL selects for.
my $Groups = new RT::Groups($session{'CurrentUser'});
#TODO: limit this to non-pseudogroups
$Groups->LimitToReal();
my $PseudoGroups = new RT::Groups($session{'CurrentUser'});
#TODO: limit this to non-pseudogroups
$PseudoGroups->LimitToPseudo;
# }}}
# }}}
</%INIT>
<%ARGS>
$id => undef
$UserString => undef
$UserOp => undef
$UserField => undef
@CheckACL => undef
</%ARGS>
|