From c587b5fdc7175c2a752558efccfc3f424cff6c0d Mon Sep 17 00:00:00 2001 From: mark Date: Sat, 1 Jan 2011 00:47:01 +0000 Subject: limit ticket creation queue dropdowns based on ACL, RT#7778 --- rt/FREESIDE_MODIFIED | 15 ++++- rt/Makefile.in | 1 + rt/configure.ac | 3 +- rt/lib/RT/Interface/Web.pm | 2 - rt/lib/RT/Principal_Overlay.pm | 4 ++ rt/lib/RT/Queue_Overlay.pm | 4 ++ rt/lib/RT/System.pm | 22 +++++++ rt/lib/RT/Test.pm | 3 + rt/sbin/rt-session-viewer.in | 121 +++++++++++++++++++++++++++++++++++++ rt/share/html/Elements/SelectQueue | 17 ++++-- rt/share/html/Ticket/Create.html | 1 + 11 files changed, 185 insertions(+), 8 deletions(-) create mode 100644 rt/sbin/rt-session-viewer.in (limited to 'rt') diff --git a/rt/FREESIDE_MODIFIED b/rt/FREESIDE_MODIFIED index aea074a82..73471247a 100644 --- a/rt/FREESIDE_MODIFIED +++ b/rt/FREESIDE_MODIFIED @@ -29,6 +29,20 @@ lib/RT/URI/freeside.pm lib/RT/URI/freeside/Internal.pm lib/RT/URI/freeside/XMLRPC.pm +# 3.9-fix-queue-caching bugfix branch +# github.com/bestpractical/rt/commit/7e211c1199836d49f007d7f677105e5c73cc0348 +Makefile.in +configure.ac +lib/RT/Principal_Overlay.pm +lib/RT/Queue_Overlay.pm +lib/RT/System.pm +lib/RT/Test.pm +lib/RT/Interface/Web.pm +sbin/rt-session-viewer.in +share/html/Elements/SelectQueue + +share/html/Ticket/Create.html # queue select dropdown on Ticket/Create + share/html/autohandler #Footer getting appended where unwelcome share/html/index.html #option to redirect to ticket display on quick create share/html/Admin/CustomFields/Modify.html #CheckMandatoryFields @@ -51,7 +65,6 @@ share/html/Elements/ShowLink_Checklist share/html/Elements/SelectCustomerAgent #SearchCustomerFields share/html/Elements/SelectCustomerClass #SearchCustomerFields share/html/Elements/SelectCustomerTag #SearchCustomerFields - html/Ticket/Create.html #XXX TODO share/html/Search/Build.html share/html/Search/Elements/BuildFormatString share/html/Search/Elements/PickCFs #customfield date patch diff --git a/rt/Makefile.in b/rt/Makefile.in index bef1025f3..1f42102aa 100644 --- a/rt/Makefile.in +++ b/rt/Makefile.in @@ -169,6 +169,7 @@ SYSTEM_BINARIES = rt-dump-database \ rt-email-dashboards \ rt-email-group-admin \ rt-server \ + rt-session-viewer \ rt-test-dependencies \ rt-clean-sessions \ rt-shredder \ diff --git a/rt/configure.ac b/rt/configure.ac index 6bac3b11f..ce9138d7f 100644 --- a/rt/configure.ac +++ b/rt/configure.ac @@ -3,7 +3,7 @@ dnl dnl Process this file with autoconf to produce a configure script dnl dnl Embed in generated ./configure script the following CVS info: -AC_REVISION($Revision: 1.1.1.12 $)dnl +AC_REVISION($Revision: 1.2 $)dnl dnl Setup autoconf AC_PREREQ([2.53]) @@ -398,6 +398,7 @@ AC_CONFIG_FILES([ etc/upgrade/3.8-ical-extension etc/upgrade/split-out-cf-categories sbin/rt-attributes-viewer + sbin/rt-session-viewer sbin/rt-dump-database sbin/rt-setup-database sbin/rt-test-dependencies diff --git a/rt/lib/RT/Interface/Web.pm b/rt/lib/RT/Interface/Web.pm index edb719df5..106209d64 100644 --- a/rt/lib/RT/Interface/Web.pm +++ b/rt/lib/RT/Interface/Web.pm @@ -1345,8 +1345,6 @@ sub ParseDateToISO { sub ProcessACLChanges { my $ARGSref = shift; - #XXX: why don't we get ARGSref like in other Process* subs? - my @results; foreach my $arg ( keys %$ARGSref ) { diff --git a/rt/lib/RT/Principal_Overlay.pm b/rt/lib/RT/Principal_Overlay.pm index 75f89ca68..42474f863 100644 --- a/rt/lib/RT/Principal_Overlay.pm +++ b/rt/lib/RT/Principal_Overlay.pm @@ -163,6 +163,8 @@ sub GrantRight { my $type = $self->_GetPrincipalTypeForACL(); + RT->System->QueueCacheNeedsUpdate(1) if $args{'Right'} eq 'SeeQueue'; + # If it's a user, we really want to grant the right to their # user equivalence group return $ace->Create( @@ -210,6 +212,8 @@ sub RevokeRight { PrincipalType => $type, PrincipalId => $self->Id ); + + RT->System->QueueCacheNeedsUpdate(1) if $args{'Right'} eq 'SeeQueue'; return ($status, $msg) unless $status; return $ace->Delete; } diff --git a/rt/lib/RT/Queue_Overlay.pm b/rt/lib/RT/Queue_Overlay.pm index 98bdec579..dcca84eb4 100644 --- a/rt/lib/RT/Queue_Overlay.pm +++ b/rt/lib/RT/Queue_Overlay.pm @@ -381,6 +381,8 @@ sub Create { unless $status; } + RT->System->QueueCacheNeedsUpdate(1); + return ( $id, $self->loc("Queue created") ); } @@ -421,6 +423,8 @@ sub SetDisabled { $RT::Handle->Commit(); + RT->System->QueueCacheNeedsUpdate(1); + if ( $val == 1 ) { return (1, $self->loc("Queue disabled")); } else { diff --git a/rt/lib/RT/System.pm b/rt/lib/RT/System.pm index 2a23e32e4..e61e35f27 100644 --- a/rt/lib/RT/System.pm +++ b/rt/lib/RT/System.pm @@ -189,6 +189,28 @@ sub SubjectTag { return grep !$seen{lc $_}++, values %$map; } +=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}); eval "require RT::System_Local"; diff --git a/rt/lib/RT/Test.pm b/rt/lib/RT/Test.pm index b8d1683d0..64b736fad 100644 --- a/rt/lib/RT/Test.pm +++ b/rt/lib/RT/Test.pm @@ -1027,6 +1027,9 @@ sub start_standalone_server { $RT::Handle->dbh( undef ); RT->ConnectToDatabase; + # the attribute cache holds on to a stale dbh + delete $RT::System->{attributes}; + return ($ret, RT::Test::Web->new); } diff --git a/rt/sbin/rt-session-viewer.in b/rt/sbin/rt-session-viewer.in new file mode 100644 index 000000000..37e050a27 --- /dev/null +++ b/rt/sbin/rt-session-viewer.in @@ -0,0 +1,121 @@ +#!@PERL@ +# BEGIN BPS TAGGED BLOCK {{{ +# +# COPYRIGHT: +# +# This software is Copyright (c) 1996-2010 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 +# you are the copyright holder for those contributions and you grant +# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable, +# 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 }}} +use strict; +use warnings; + +# fix lib paths, some may be relative +BEGIN { + require File::Spec; + my @libs = ("@RT_LIB_PATH@", "@LOCAL_LIB_PATH@"); + my $bin_path; + + for my $lib (@libs) { + unless ( File::Spec->file_name_is_absolute($lib) ) { + unless ($bin_path) { + if ( File::Spec->file_name_is_absolute(__FILE__) ) { + $bin_path = ( File::Spec->splitpath(__FILE__) )[1]; + } + else { + require FindBin; + no warnings "once"; + $bin_path = $FindBin::Bin; + } + } + $lib = File::Spec->catfile( $bin_path, File::Spec->updir, $lib ); + } + unshift @INC, $lib; + } +} + +use Getopt::Long; +my %opt; +GetOptions( \%opt, 'help|h', ); + +my $session_id = shift; + +if ( $opt{help} || !$session_id ) { + require Pod::Usage; + Pod::Usage::pod2usage({ verbose => 2 }); + exit; +} + +require RT; +RT::LoadConfig(); +RT::Init(); + +require RT::Interface::Web::Session; +my %session; + +tie %session, 'RT::Interface::Web::Session', $session_id; +unless ( $session{'_session_id'} eq $session_id ) { + print STDERR "Couldn't load session $session_id\n"; + exit 1; +} + +use Data::Dumper; +print "Content of session $session_id: ". Dumper( \%session); + +__END__ + +=head1 NAME + +rt-session-viewer - show the content of a user's session + +=head1 SYNOPSIS + + # show the content of a session + rt-session-viewer 2c21c8a2909c14eff12975dd2cc7b9a3 + +=head1 DESCRIPTION + +This script deserializes and print content of a session identified +by . May be useful for developers and for troubleshooting +problems. + +=cut diff --git a/rt/share/html/Elements/SelectQueue b/rt/share/html/Elements/SelectQueue index c78afe9ce..5b146a7f6 100755 --- a/rt/share/html/Elements/SelectQueue +++ b/rt/share/html/Elements/SelectQueue @@ -55,7 +55,7 @@ % if ($ShowNullOption) { % } -% for my $queue (@{$session{$cache_key}}) { +% for my $queue (@{$session{$cache_key}{queues}}) {