%# BEGIN BPS TAGGED BLOCK {{{
%# 
%# COPYRIGHT:
%#  
%# This software is Copyright (c) 1996-2007 Best Practical Solutions, LLC 
%#                                          <jesse@bestpractical.com>
%# 
%# (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/copyleft/gpl.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 }}}
<%init>
if (    $session{'CurrentUser'}->Name eq ($RT::WebPublicUser||'')
     or defined $session{'BitcardUser'} or defined $session{'CurrentUser'}->{'OpenID'} )
{
    # This is a public user, we only want them going to /Public/
    #
    # The following logic is very similar to the priv/unpriv logic
    #
    my $path = $m->request_comp->path;

    # if the user is trying to access a ticket, redirect them
    if ( $path =~ '^(/+)Ticket/Display.html'
            and $ARGS{'id'} )
    {
        $m->redirect($RT::WebPath . "/Public/Bug/Display.html?id="
                        . $m->interp->apply_escapes($ARGS{'id'}, 'u'));
        $m->abort();
    }

    elsif ( $path =~ '^(/+)Dist/Display.html' and $ARGS{'Queue'} ) {
        $m->redirect($RT::WebPath . "/Public/Dist/Display.html?Name="
                        . $m->interp->apply_escapes($ARGS{'Queue'}, 'u'));
    }

    # otherwise, drop the user at the Public default page
    # XXX: don't we want to check against 'NoAuthRegexp' instead???
    elsif (    $path !~ '^(/+)Public/'
           and $path !~ '^(/+)NoAuth/'
           and $path !~ '^(/+)Ticket/Attachment/') {
        $m->redirect($RT::WebPath . "/Public/");
        $m->abort();
    }
}
</%init>
