X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Flib%2FRT%2FSystem.pm;h=8e5f963688c57eefc2eec1b6ea1804d5e2d8f75c;hb=90edd8a914fd484e649fb0aa051dce7927bd6881;hp=2d9ebb07d5380d142a061e197f89539bb144d9db;hpb=2dfda73eeb3eae2d4f894099754794ef07d060dd;p=freeside.git diff --git a/rt/lib/RT/System.pm b/rt/lib/RT/System.pm index 2d9ebb07d..8e5f96368 100644 --- a/rt/lib/RT/System.pm +++ b/rt/lib/RT/System.pm @@ -1,40 +1,40 @@ # BEGIN BPS TAGGED BLOCK {{{ -# +# # COPYRIGHT: -# -# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC -# -# +# +# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC +# +# # (Except where explicitly superseded by other copyright notices) -# -# +# +# # LICENSE: -# +# # This work is made available to you under the terms of Version 2 of # the GNU General Public License. A copy of that license should have # been provided with this software, but in any event can be snarfed # from www.gnu.org. -# +# # This work is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. -# +# # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA # 02110-1301 or visit their web page on the internet at # http://www.gnu.org/licenses/old-licenses/gpl-2.0.html. -# -# +# +# # CONTRIBUTION SUBMISSION POLICY: -# +# # (The following paragraph is not intended to limit the rights granted # to you to modify and distribute this software under the terms of # the GNU General Public License and is only of importance to you if # you choose to contribute your changes and enhancements to the # community by submitting them to Best Practical Solutions, LLC.) -# +# # By intentionally submitting any modifications, corrections or # derivatives to this work, or any other work intended for use with # Request Tracker, to Best Practical Solutions, LLC, you confirm that @@ -43,8 +43,9 @@ # royalty-free, perpetual, license to use, copy, create derivative # works based on those contributions, and sublicense and distribute # those contributions and any derivatives thereof. -# +# # END BPS TAGGED BLOCK }}} + =head1 NAME RT::System @@ -65,19 +66,19 @@ In the future, there will probably be other API goodness encapsulated here. package RT::System; -use base qw /RT::Record/; + use strict; +use warnings; +use base qw/RT::Record/; use RT::ACL; -use vars qw/ $RIGHTS/; # System rights are rights granted to the whole system # XXX TODO Can't localize these outside of having an object around. -$RIGHTS = { +our $RIGHTS = { SuperUser => 'Do anything and everything', # loc_pair AdminAllPersonalGroups => - "Create, delete and modify the members of any user's personal groups" - , # loc_pair + "Create, delete and modify the members of any user's personal groups", # loc_pair AdminOwnPersonalGroups => 'Create, delete and modify the members of personal groups', # loc_pair AdminUsers => 'Create, delete and modify users', # loc_pair @@ -85,6 +86,7 @@ $RIGHTS = { DelegateRights => "Delegate specific rights which have been granted to you.", # loc_pair ShowConfigTab => "show Configuration tab", # loc_pair + ShowApprovalsTab => "show Approvals tab", # loc_pair LoadSavedSearch => "allow loading of saved searches", # loc_pair CreateSavedSearch => "allow creation of saved searches", # loc_pair }; @@ -99,25 +101,20 @@ foreach my $right ( keys %{$RIGHTS} ) { =head2 AvailableRights -Returns a hash of available rights for this object. The keys are the right names and the values are a description of what the rights do - -=begin testing - -my $s = RT::System->new($RT::SystemUser); -my $rights = $s->AvailableRights; -ok ($rights, "Rights defined"); -ok ($rights->{'AdminUsers'},"AdminUsers right found"); -ok ($rights->{'CreateTicket'},"CreateTicket right found"); -ok ($rights->{'AdminGroupMembership'},"ModifyGroupMembers right found"); -ok (!$rights->{'CasdasdsreateTicket'},"bogus right not found"); - - - -=end testing +Returns a hash of available rights for this object. +The keys are the right names and the values are a +description of what the rights do. +This method as well returns rights of other RT objects, +like L or L. To allow users to apply +those rights globally. =cut + +use RT::CustomField; +use RT::Queue; +use RT::Group; sub AvailableRights { my $self = shift; @@ -125,15 +122,31 @@ sub AvailableRights { my $group = RT::Group->new($RT::SystemUser); my $cf = RT::CustomField->new($RT::SystemUser); - my $qr =$queue->AvailableRights(); + my $qr = $queue->AvailableRights(); my $gr = $group->AvailableRights(); my $cr = $cf->AvailableRights(); # Build a merged list of all system wide rights, queue rights and group rights. my %rights = (%{$RIGHTS}, %{$gr}, %{$qr}, %{$cr}); + return(\%rights); } +=head2 AddRights C, C [, ...] + +Adds the given rights to the list of possible rights. This method +should be called during server startup, not at runtime. + +=cut + +sub AddRights { + my $self = shift if ref $_[0] or $_[0] eq __PACKAGE__; + my %new = @_; + $RIGHTS = { %$RIGHTS, %new }; + %RT::ACE::LOWERCASERIGHTNAMES = ( %RT::ACE::LOWERCASERIGHTNAMES, + map { lc($_) => $_ } keys %new); +} + sub _Init { my $self = shift; $self->SUPER::_Init (@_) if @_ && $_[0]; @@ -143,24 +156,10 @@ sub _Init { Returns RT::System's id. It's 1. - -=begin testing - -use RT::System; -my $sys = RT::System->new(); -is( $sys->Id, 1); -is ($sys->id, 1); - -=end testing - - =cut *Id = \&id; - -sub id { - return (1); -} +sub id { return 1 } =head2 Load @@ -169,18 +168,48 @@ It does nothing =cut -sub Load { - return (1); -} +sub Load { return 1 } +sub Name { return 'RT System' } +sub __Set { return 0 } +sub __Value { return 0 } +sub Create { return 0 } +sub Delete { return 0 } + +sub SubjectTag { + my $self = shift; + my $queue = shift; + + my $map = $self->FirstAttribute('BrandedSubjectTag'); + $map = $map->Content if $map; + return $queue ? undef : () unless $map; -sub Name { - return 'RT System'; + return $map->{ $queue->id } if $queue; + + my %seen = (); + return grep !$seen{lc $_}++, values %$map; } -sub __Set { 0 } -sub __Value { 0 } -sub Create { 0 } -sub Delete { 0 } +=head2 QueueCacheNeedsUpdate ( 1 ) + +Attribute to decide when SelectQueue needs to flush the list of queues + and retrieve new ones. Set when queues are created, enabled/disabled + and on certain acl changes. Should also better understand group management. + +If passed a true value, will update the attribute to be the current time. + +=cut + +sub QueueCacheNeedsUpdate { + my $self = shift; + my $update = shift; + + if ($update) { + return $self->SetAttribute(Name => 'QueueCacheNeedsUpdate', Content => time); + } else { + my $cache = $self->FirstAttribute('QueueCacheNeedsUpdate'); + return (defined $cache ? $cache->Content : 0 ); + } +} eval "require RT::System_Vendor"; die $@ if ($@ && $@ !~ qr{^Can't locate RT/System_Vendor.pm});