X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FElements%2FMyRT;h=56aa8bdd01c6ae4fd76c0b6ab5560be021eb9294;hp=7b719fd422deefef49b22a1e2767c8536289b960;hb=187086c479a09629b7d180eec513fb7657f4e291;hpb=63a268637b2d51a8766412617724b9436439deb6 diff --git a/rt/share/html/Elements/MyRT b/rt/share/html/Elements/MyRT index 7b719fd42..56aa8bdd0 100644 --- a/rt/share/html/Elements/MyRT +++ b/rt/share/html/Elements/MyRT @@ -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-2018 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,7 +43,7 @@ %# 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 }}} % $m->callback( ARGSRef => \%ARGS, CallbackName => 'BeforeTable' ); @@ -53,9 +53,9 @@ % $show_cb->($_) foreach @$body; -% if ( $summary ) { +% if ( $sidebar ) { % } @@ -63,24 +63,24 @@ % $m->callback( ARGSRef => \%ARGS, CallbackName => 'AfterTable' ); <%INIT> -# XXX: we don't use this, but should. my %allowed_components = map {$_ => 1} @{RT->Config->Get('HomepageComponents')}; my $user = $session{'CurrentUser'}->UserObj; -$Portlets ||= $session{'my_rt_portlets'}; unless ( $Portlets ) { - my ($default_portlets) = RT::System->new($session{'CurrentUser'})->Attributes->Named('HomepageSettings'); - $Portlets = $session{'my_rt_portlets'} = $user->Preferences( - HomepageSettings => $default_portlets? $default_portlets->Content: {}, + my ($defaults) = RT::System->new($session{'CurrentUser'})->Attributes->Named('HomepageSettings'); + $Portlets = $user->Preferences( + HomepageSettings => $defaults ? $defaults->Content : {} ); } -my ($body, $summary) = @{$Portlets}{qw(body summary)}; +$m->callback( CallbackName => 'MassagePortlets', Portlets => $Portlets ); + +my ($body, $sidebar) = @{$Portlets}{qw(body sidebar)}; unless( $body && @$body ) { - $body = $summary || []; - $summary = undef; + $body = $sidebar || []; + $sidebar = undef; } -$summary = undef unless $summary && @$summary; +$sidebar = undef unless $sidebar && @$sidebar; my $Rows = $user->Preferences( 'SummaryRows', ( RT->Config->Get('DefaultSummaryRows') || 10 ) ); @@ -89,12 +89,16 @@ my $show_cb = sub { my $type = $entry->{type}; my $name = $entry->{'name'}; if ( $type eq 'component' ) { - # XXX: security check etc. - $m->comp( $name, %{ $entry->{arguments} || {} } ); + if (!$allowed_components{$name}) { + $m->out( $m->interp->apply_escapes( loc("Invalid portlet [_1]", $name), "h" ) ); + } + else { + $m->comp( $name, %{ $entry->{arguments} || {} } ); + } } elsif ( $type eq 'system' ) { $m->comp( '/Elements/ShowSearch', Name => $name, Override => { Rows => $Rows } ); } elsif ( $type eq 'saved' ) { - $m->comp( '/Elements/ShowSearch', SavedSearch => $name, Override => { Rows => $Rows }, IgnoreMissing => 1 ); + $m->comp( '/Elements/ShowSearch', SavedSearch => $name, Override => { Rows => $Rows } ); } else { $RT::Logger->error("unknown portlet type '$type'"); }
-% $show_cb->($_) foreach @$summary; +% $show_cb->($_) foreach @$sidebar;